我想写一下 Java的文字,即,在保护视觉形象(但不一定是变态或其他动态行为)的同时,“flattens”一词是任意的网页。
在理论上,我认为,这只是一个记录每个与窗户有关的内容的问题(例如:x. findPos(element)>),以及它所篡改的CSS风格(e.x.
我在此方法上取得了一些成功,但并不十分完美:function walkDOM(element, parent, nodes) {
parent = parent || { top : 0, left : 0, depth : 0 };
nodes = nodes || [];
if (element.nodeType === 1) {
var node = findPos(element);
node.element = element;
node.width = element.scrollWidth;
node.height = element.scrollHeight;
node.depth = parent.depth + 1;
node.cssText = window.getComputedStyle(element).cssText;
nodes.push(node);
for (var i = 0; i < element.childNodes.length; i++) {
walkDOM(element.childNodes[i], node, nodes);
}
}
return nodes;
}
// based on http://www.quirksmode.org/js/findpos.html
function findPos(element) {
var position = { left : 0, top : 0 };
if (element.offsetParent) {
do {
position.left += element.offsetLeft;
position.top += element.offsetTop;
} while (element = element.offsetParent);
}
return position;
}
var nodes = walkDOM(document.body);
nodes.forEach(function(node) {
var e = node.element;
if (e !== document.body)
e.parentNode.removeChild(e);
// e.setAttribute("style", node.cssText);
e.style.position = "absolute";
e.style.top = node.top + "px";
e.style.left = node.left + "px";
e.style.width = node.width + "px";
e.style.height = node.height + "px";
e.style.zIndex = node.depth + 1;
if (e !== document.body)
document.body.appendChild(e);
});