Heim  >  Artikel  >  Web-Frontend  >  Native js-Operation dom

Native js-Operation dom

小云云
小云云Original
2017-12-08 16:35:311915Durchsuche

In diesem Artikel zeigen wir Ihnen, wie Sie dom mit nativem js bedienen. Wir hoffen, dass es für alle nützlich ist.

ng-click="brandFnc($event)"$scope.brandFnc = function($event) {
    // 通过 $event.target 来获取
}
ev.target.parentElementev.target.parentElement.children[0].srcev.target.previousElementSiblingev.target.nodeNameconsole.log(ev.target.outerHTML);//<button ng-click="ngGetSrc($event)">获取src</button>---整个console.log(ev.target.innerHTML);//获取src--中间的内容原生js的方法:1)创建节点:createElement创建元素,
也可以使用createTextNode创建文本节点.
document.body指向的是<body>元素;document.documentElement则指向<html>元素
    //创建节点
    var createNode = document.createElement("p");
    var createTextNode = document.createTextNode("hello world");
    createNode.appendChild(createTextNode);
    document.body.appendChild(createNode);
    document.documentElement.appendChild(createNode);2)插入节点:appendChild,insertBefore,
insertBefore接收两个参数,第一个是插入的节点,第二个是参照节点,如insertBefore(a,b),则a会插入在b的前面
//插入节点
 var createNode = document.createElement("p");var createTextNode = document.createTextNode("hello world");
  createNode.appendChild(createTextNode);
 var p1 = document.getElementById("p1");
 document.body.insertBefore(createNode,p1);3)替换和删除元素,从replaceChild和removeChild的字面意思看,就是删除子节点,因此调用者,需要包含子节点p1,不然调用会报错。返回的节点是替换的或删除的元素,被替换/删除的元素仍然存在,但document中已经没有他们的位置了。
//替换元素
var replaceChild = document.body.replaceChild(createNode,p1);//删除元素
var removeChild = document.body.removeChild(p1);4)节点的属性:firstChild:第一个子节点lastChild:最后一个子节点childNodes:子节点集合,获取其中子节点可以someNode.childNodes[index]或者someNode.childNodes.item(index)nextSibling:下一个兄弟节点
previousSibling:上一个兄弟节点
parentNode:父节点
<ul id="ul"><li>sdsssssss</li><li>qqqq</li><li>wwww</li><li>eeee</li></ul>
复制代码
   //节点属性
    var ul = document.getElementById("ul");
    var firstChild = ul.firstChild;
    console.log(firstChild.innerHTML);
    var lastChild = ul.lastChild;
    console.log(lastChild.innerHTML);
    var length = ul.childNodes.length;
    console.log(length);
    var secondChild = ul.childNodes.item(1);
    console.log(secondChild.innerHTML);
    var forthChild = ul.childNodes.item(2).nextSibling;
    console.log(forthChild.innerHTML);
    var thridChild = forthChild.previousSibling;
    console.log(thridChild.innerHTML);
    var parentNode = forthChild.parentNode;
    console.log(parentNode.innerHTML);5) 文档片段,好处在于减少dom的渲染次数,可以优化性能。
//文本片段
    var fragment = document.createDocumentFragment();
    var ul = document.getElementById("ul");
    var li = null;
    for (var i = 4; i >= 0; i--) {
        li = document.createElement("li");
        li.appendChild(document.createTextNode("item "+i));
        fragment.appendChild(li);
    }
    ul.appendChild(fragment);6)克隆元素
someNode.cloneNode(true):深度克隆,会复制节点及整个子节点
someNode.cloneNode(false):浅克隆,会复制节点,但不复制子节点 
//克隆
    var clone = ul.cloneNode(true);

document.body.appendChild(clone);

Hinweis: 1. childNodes.length hat browserübergreifende Probleme

Sie können das Relevante sehen Das HTML-Fragment der Liste verwendet nicht das Schreibformat

<ul id="ul">
<li>sdsssssss</li>
<li>qqqq</li>
<li>wwww</li>
<li>eeee</li>
</ul>

, sondern ein Format ohne Zeilenumbrüche, da die Ergebnisse beim Abrufen von ul.childNodes.length in verschiedenen Browsern unterschiedlich sind :
Im IE berechnet ul.childNodes.length nicht den Zeilenumbruch zwischen li, daher ist der Wert 4. In ff, Chrome und Safari gibt es 5 Textknoten, die den Leerraum zwischen li enthalten, also ul.childNodes. Die Länge beträgt 9. Um das browserübergreifende Problem zu lösen, können Sie die Zeilenumbrüche zwischen li entfernen und in ein einzeiliges Schreibformat ändern.
2. CloneNode weist browserübergreifende Probleme auf.
Im IE kopieren Elemente, die über die cloneNode-Methode kopiert werden, den Ereignishandler, z. B. var b = a.cloneNode(true). Ereignisüberwachung, dann verfügt b auch über diese Ereignisüberwachung.

In ff, Chrome und Safari kopieren Elemente, die über die cloneNode-Methode kopiert werden, nur die Attribute und nichts anderes wird kopiert.
Um das browserübergreifende Problem zu lösen, ist es daher am besten, Folgendes zu tun Vor dem Kopieren kopieren. Am besten entfernen Sie zuerst den Event-Handler.

ng-click="brandFnc($event)"$scope.brandFnc = function($event) {
    // 通过 $event.target 来获取
}
ev.target.parentElementev.target.parentElement.children[0].srcev.target.previousElementSiblingev.target.nodeNameconsole.log(ev.target.outerHTML);//<button ng-click="ngGetSrc($event)">获取src</button>---整个console.log(ev.target.innerHTML);//获取src--中间的内容原生js的方法:1)创建节点:createElement创建元素,
也可以使用createTextNode创建文本节点.
document.body指向的是<body>元素;document.documentElement则指向<html>元素
    //创建节点
    var createNode = document.createElement("p");

    var createTextNode = document.createTextNode("hello world");

    createNode.appendChild(createTextNode);

    document.body.appendChild(createNode);

    document.documentElement.appendChild(createNode);2)插入节点:appendChild,insertBefore,
insertBefore接收两个参数,第一个是插入的节点,第二个是参照节点,如insertBefore(a,b),则a会插入在b的前面
//插入节点

 var createNode = document.createElement("p");var createTextNode = document.createTextNode("hello world");

  createNode.appendChild(createTextNode);

 var p1 = document.getElementById("p1");

 document.body.insertBefore(createNode,p1);3)替换和删除元素,从replaceChild和removeChild的字面意思看,就是删除子节点,因此调用者,需要包含子节点p1,不然调用会报错。返回的节点是替换的或删除的元素,被替换/删除的元素仍然存在,但document中已经没有他们的位置了。
//替换元素

var replaceChild = document.body.replaceChild(createNode,p1);//删除元素
var removeChild = document.body.removeChild(p1);4)节点的属性:firstChild:第一个子节点lastChild:最后一个子节点childNodes:子节点集合,获取其中子节点可以someNode.childNodes[index]或者someNode.childNodes.item(index)nextSibling:下一个兄弟节点
previousSibling:上一个兄弟节点
parentNode:父节点

<ul id="ul"><li>sdsssssss</li><li>qqqq</li><li>wwww</li><li>eeee</li></ul>

复制代码

   //节点属性

    var ul = document.getElementById("ul");

    var firstChild = ul.firstChild;

    console.log(firstChild.innerHTML);

    var lastChild = ul.lastChild;

    console.log(lastChild.innerHTML);

    var length = ul.childNodes.length;

    console.log(length);



    var secondChild = ul.childNodes.item(1);

    console.log(secondChild.innerHTML);



    var forthChild = ul.childNodes.item(2).nextSibling;

    console.log(forthChild.innerHTML);

    var thridChild = forthChild.previousSibling;

    console.log(thridChild.innerHTML);



    var parentNode = forthChild.parentNode;

    console.log(parentNode.innerHTML);5) 文档片段,好处在于减少dom的渲染次数,可以优化性能。

//文本片段

    var fragment = document.createDocumentFragment();

    var ul = document.getElementById("ul");

    var li = null;

    for (var i = 4; i >= 0; i--) {

        li = document.createElement("li");

        li.appendChild(document.createTextNode("item "+i));

        fragment.appendChild(li);

    }

    ul.appendChild(fragment);6)克隆元素
someNode.cloneNode(true):深度克隆,会复制节点及整个子节点
someNode.cloneNode(false):浅克隆,会复制节点,但不复制子节点 
//克隆

    var clone = ul.cloneNode(true);

    document.body.appendChild(clone);注意:1、childNodes.length存在跨浏览器的问题


可以看到有关列表的html片段没有用 
<ul id="ul">
<li>sdsssssss</li>
<li>qqqq</li>
<li>wwww</li>
<li>eeee</li>
</ul>

Dieses Schreibformat ist in einem Format ohne Zeilenumbrüche geschrieben, da in verschiedenen Browsern ul.childNodes erhalten wird. Die Ergebnisse von .length sind unterschiedlich:
Im IE berechnet ul.childNodes.length nicht den Zeilenumbruch zwischen li, daher ist der Wert 4. In ff, chrome und safari gibt es einen Leerraum zwischen li. Es gibt 5 Textknoten von das Symbol, also ist ul.childNodes.length 9. Um das browserübergreifende Problem zu lösen, können Sie die Zeilenumbrüche zwischen li entfernen und es in ein einzeiliges Schreibformat ändern.
2. CloneNode weist browserübergreifende Probleme auf.
Im IE kopieren Elemente, die über die cloneNode-Methode kopiert werden, den Ereignishandler, z. B. var b = a.cloneNode(true). Ereignisüberwachung, dann verfügt b auch über diese Ereignisüberwachung.

In ff, Chrome und Safari kopieren Elemente, die über die cloneNode-Methode kopiert werden, nur die Attribute und nichts anderes wird kopiert.
Um das browserübergreifende Problem zu lösen, ist es daher am besten, Folgendes zu tun Vor dem Kopieren kopieren. Am besten entfernen Sie zuerst den Event-Handler.

Verwandte Empfehlungen:

Js-Prozess zum Betreiben von DOM-Objekten

Analyse von DOM-Betriebsbeispielen in jQuery

Wie Js DOM betreibt und Browserhöhe und -breite erhält

Das obige ist der detaillierte Inhalt vonNative js-Operation dom. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Vorheriger Artikel:js Multi-Touch-ProblemNächster Artikel:js Multi-Touch-Problem