对于“可能的”javascript方式,请参阅下面的@sabof答案:
https://stackoverflow.com/a/22172009/3309243
……….
JQUERY
事件:
我很快做了一个函数getEvents()的例子,但它似乎工作:)
属性:
我在互联网上找到了这个,通过使用.attr()返回所有属性
我刚刚发现了在浏览器中进行调试,因此现在知道如何查看对象.
可能有人想知道如何:打开你的控制台(f12至少在FireFox中)并在控制台命令行中输入例如$(“body”)(一直在底部),单击返回的对象并查看右边的控制台:P
//extending the attr function to return all attrs (function($) { // duck-punching to make attr() return a map var _old = $.fn.attr; $.fn.attr = function() { var a,aLength,attributes,map; if (this[0] && arguments.length === 0) { map = {}; attributes = this[0].attributes; aLength = attributes.length; for (a = 0; a < aLength; a++) { map[attributes[a].name.toLowerCase()] = attributes[a].value; } return map; } else { return _old.apply(this,arguments); } } }(jQuery));
感谢@ user3331198的一个很好的例子,我得到了以下内容(使用上面的代码块).
var href = "http://www.google.com/"; var text = "Google"; $( document ).ready(function() { $("body").css({"background-color": "#000fff"}) .append( $("<div>",{class: 'foo'})) .append($("<a>",{ id: "anID",href: href,text: text })) .append($("<span>").text("Foo").on("click",function(){ alert('!')})); loopDOM($("body")); }); function loopDOM(obj,parentID=-1,thisID=0) { saveToDB({ id: thisID,parent: parentID,tag: obj.prop("tagName"),style: obj.attr("style"),events: getEvents(obj),attribs: obj.attr() }); obj.children().each(function() { loopDOM($(this),thisID,++thisID) }); } function getEvents(obj) { aEvents=[]; if (typeof $._data( obj[0],'events' )==="object") { $.each($._data( obj[0],'events' ),function(i,event) { type=JSON.stringify(i); aEvents[type]=[]; $.each(event,function(j,h) { aEvents[type][aEvents[type].length]=h.handler; }); }); } return aEvents; } function saveToDB(pass) { alert("id:"+pass["id"]+"\nparent:"+pass["parent"]+"\ntag:"+pass["tag"]+"\nstyle:"+pass["style"]); alert ("has the following attributes"); for (var x in pass["attribs"]) alert("attrib: "+x+" "+pass["attribs"][x]); alert ("has the following events"); for (var x in pass["events"]) alert("event: "+x+" "+pass["events"][x]); }
………………………………………….. ……………………
原始帖子
我在业余时间四处奔波,以便通过编码恢复原状.
例如,我正在构建这个DOM(使用jQuery而不是纯HTML的练习)
$(document).ready(function() { $("body").css({"background-color": "#000fff"}) .append( $("<div>",{ class: "foo" }) .append($("<a>",{ href: href,text: text }) .on("click",function(){ alert('!')})) .append($("<span>").text("Foo"))); });
现在假设我想将DOM保存在DB表中,如下所示:
| ID | parentID | tag | style | events | atribs | _________________________________________________________ | 0 | -1 | <body> | backgr... | NULL | NULL | | 1 | 0 | <div> | NULL | NULL | class:.| | 2 | 1 | <a> | NULL | click..| NULL | | 3 | 2 | <span> | NULL | NULL | NULL |
用于使用一些JS函数检索和重建DOM
要做到这一点,我会使用一些像这样的递归循环:(有点伪JS)
function loopDOM(obj,thisID=0) { saveToDB({ id: thisID,style: obj.getStyle,events: obj.getEvents,atribs: obj.getAtribs }); obj.each(function() { loopDOM(child,++thisID) }); }
但我完全陷入了这里的每一点.我一直在寻找至少45分钟,但即使是我以下的一个问题也无法回答.
>如何循环$(‘body’)?如何从元素中检索其子元素?我找到了.each,.find,.children,但我找不到像< div>那样传递的正确对象.这是< body>的孩子.
我无法弄清楚如何递归循环对象.
>如何获取元素的所有(未知)事件,属性和CSS?我无法做出我找到的任何答案.
………………………………………….. ……………………
编辑1(过时)
如果我快速地将链接@PellePenna发布到我发布了这个…但它的jquery和javascript混合并且它确实有效.我没有得到attribs和事件.而且我不知道如何让元素成为他的位置.
我可能有点沮丧,但我没有得到建议.并且还非常喜欢递归循环:P
var el = this.getElementsByTagName("*"); for (var i = el.length; i--;) { //get atribs var nodes=[],values=[]; if (el.attributes) for (var attr,i=0,attrs=el.attributes,l=attrs.length; i<l; i++){ attr = attrs.item(i) nodes.push(attr.nodeName); values.push(attr.nodeValue); } //get events event=$._data(el,'events'); }