javascript – 如何循环HTML DOM?以及如何获取元素的事件,风格和属性(例如)

前端之家收集整理的这篇文章主要介绍了javascript – 如何循环HTML DOM?以及如何获取元素的事件,风格和属性(例如)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
编辑2(解决方案)

使用Javascript

对于“可能的”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');
}

解决方法

试试这个 : –
function loopDOM(obj,parentID,thisID) {
   saveToDB({ 
      id: thisID,events: Object.keys($._data(obj[0],'events')),atribs: obj.attr()
   });

   obj.children().each(function() {
       loopDOM($(this),++thisID)
   });
}

第一次调用函数loopDOM($(‘body’),– 1,0)

猜你在找的JavaScript相关文章