Rumah >hujung hadapan web >tutorial js >Operasi nod JavaScript yang komprehensif dalam satu artikel

Operasi nod JavaScript yang komprehensif dalam satu artikel

WBOY
WBOYke hadapan
2022-06-10 15:18:142734semak imbas

Artikel ini membawa anda pengetahuan yang berkaitan tentang javascript, yang terutamanya memperkenalkan isu berkaitan tentang operasi nod, termasuk nod induk, nod anak, nod adik beradik, menambah, memadam dan menyalin nod kandungan di bawah, saya harap ia akan membantu semua orang.

Operasi nod JavaScript yang komprehensif dalam satu artikel

[Cadangan berkaitan: tutorial video javascript, bahagian hadapan web]

Dalam halaman web kami , Selain menggunakan kaedah yang disediakan oleh DOM untuk mendapatkan nod, anda juga boleh menggunakan perhubungan hierarki nod untuk mendapatkan nod. Mari kita ringkaskannya hari ini.

Gambaran Keseluruhan Nod

Semua kandungan dalam halaman web ialah nod (label, atribut, teks, ulasan, dll. Dalam DOM, nod diwakili oleh nod).
Semua nod dalam pepohon HTML DOM boleh diakses melalui JavaScript dan semua elemen HTML (nod) boleh diubah suai, dicipta atau dipadamkan.
Operasi nod JavaScript yang komprehensif dalam satu artikel
Secara amnya, nod mempunyai sekurang-kurangnya tiga atribut asas: nodeType (nod ​​type), nodeName (nod ​​name) dan nodeValue (node ​​​​value).

  • Tipe nod elemen ialah 1
  • Tipe nod atribut ialah 2
  • Jenis nod nod teks ialah 3 (nod teks termasuk teks, ruang, baris baharu, dsb. .)

Dalam pembangunan sebenar kami, operasi nod terutamanya beroperasi pada nod elemen.

Tahap nod

Menggunakan pepohon DOM, nod boleh dibahagikan kepada perhubungan hierarki yang berbeza Yang paling biasa ialah perhubungan hierarki antara bapa, anak dan abang.

1. Nod induk

node.parentNode

  • Atribut parentNode boleh mengembalikan nod induk nod, ambil perhatian bahawa ia adalah nod induk yang terdekat.
  • Mengembalikan null jika nod yang ditentukan tidak mempunyai nod induk.
<p>
        </p><p></p>
    
    <script>
        var son = document.querySelector(".son");
        console.log(son.parentNode);
    </script>

Operasi nod JavaScript yang komprehensif dalam satu artikel

2. Nod anak

1.node.childNodes (standard)

node.childNodes mengembalikan koleksi yang mengandungi nod anak nod yang ditentukan Koleksi ini ialah koleksi yang dikemas kini dengan serta-merta.

    
            
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •     
    <script> var ul = document.querySelector(&#39;ul&#39;); // 子节点childNodes 所有子节点,包含元素节点,文本节点等。 console.log(ul.childNodes); </script>

Operasi nod JavaScript yang komprehensif dalam satu artikel
Mengapakah terdapat lima nod teks di sini sebenarnya sepadan dengan lima pemisah baris Lihat gambar di bawah:
Operasi nod JavaScript yang komprehensif dalam satu artikel
Lima pemisah baris ini? nod teks, ditambah empat nod elemen li, sejumlah 9

Nota: Nilai pulangan mengandungi semua nod anak, termasuk nod elemen, nod teks, dsb.
Jika anda hanya ingin mendapatkan nod elemen di dalam, anda perlu mengendalikannya secara khusus. Jadi kami secara amnya tidak menyokong penggunaan childNodes.

	var ul = document.querySelector('ul');
	for (var i = 0;i

2.node.children (bukan standard)

node.children ialah sifat baca sahaja yang mengembalikan semua nod elemen anak. Ia hanya mengembalikan nod elemen kanak-kanak, dan nod lain tidak dikembalikan (inilah yang kami fokuskan).
Walaupun kanak-kanak adalah tidak standard, ia disokong oleh pelbagai pelayar, jadi kami boleh menggunakannya dengan yakin.

	
            
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •     
    <script> var ul = document.querySelector(&#39;ul&#39;); console.log(ul.children); </script>

Operasi nod JavaScript yang komprehensif dalam satu artikel

3 Nod anak pertama dan nod anak terakhir

1.nod pertama
2.nod . lastChild
firstChild mengembalikan nod anak pertama Jika ia tidak ditemui, ia akan mengembalikan nod yang sama. Begitu juga, semua nod disertakan.

3.nod firstElementChild
firstElementChild mengembalikan nod elemen anak pertama, atau null jika tidak ditemui.
4.nod lastElementChild
lastElementChild mengembalikan nod elemen anak terakhir, atau null jika tidak ditemui.

Nota: Kedua-dua kaedah ini mempunyai isu keserasian dan hanya disokong oleh IE9 dan ke atas.

5.node.children[0]
5.node.children[node.children.length - 1]
Nota: Kaedah pembangunan sebenar tidak serasi Seksual isu.

    
            
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •         
  • 我是li
  •     
    <script> var ul = document.querySelector(&#39;ul&#39;); // 1.不管是文本节点还是元素节点 console.log(ul.firstChild); console.log(ul.lastChild); // 2.返回对应的自元素节点,IE9以上才支持 console.log(ul.firstElementChild); console.log(ul.lastElementChild); // 3.不存在兼容性问题 console.log(ul.children[0]); console.log(ul.children[ul.children.length - 1]); </script>

Operasi nod JavaScript yang komprehensif dalam satu artikel

4.兄弟节点

1.node. nextSibling
nextSibling 返回当前元素的下一个兄弟节点,找不到则返回 null 。同样,也是包含所有的节点。
2.node. previousSibling
previousSibling 返回当前元素上一个兄弟节点,找不到则返回null。同样,也包含所有的节点。
3.node. nextElementSibling
nextElementSibling 返回当前元素下一个兄弟元素节点,找不到返回 null 。
4.node. previousElementSibling
previousElementSibling 返回当前元素上一个兄弟元素节点,找不则返回 null 。
注意:这两个方法有兼容性问题,IE9以上才支持。

那么如何封装一个满足兼容性,又可以找到兄弟元素节点的函数呢

   function getNextElementSibling(element){
       var el = element;
       while(el = el.nextSibling){
           if(el.nodeType == 1){
               return el;
           }
       }
       return null;
   }

上面这段封装的代码就可解决,但不必考虑太多,因为ie浏览器即将要停止服务了,所以你只要记住node. nextElementSibling 这个就行,不必担心兼容性问题。

创建节点

document.createElement (’ tagName ')

document.createElenent ()方法创建由 tagName 指定的Н TML 元素。因为这些元素原先不存在,是根据我的需求动态生成的,所以我们也称为动态创建元素节点

添加节点与添加节点

1.node. appendChild(child)

node.appendChild ()方法将一个节点添加到指定父节点的子节点列表末尾。类似 css 里面的 after 伪元素。

2.node.insertBefore(child,指定元素)

    
        <script> var ul = document.querySelector("ul"); var li =document.createElement("li"); var span = document.createElement("span") ul.appendChild(li); ul.insertBefore(span,ul.children[0]); </script>

    Operasi nod JavaScript yang komprehensif dalam satu artikel

    删除节点

    node.removeChild(child)

    node.removeChild(child) 方法从DOM中删除一个子节点,返回删除的节点。

        
              
    • aniu
    •         
    • marry
    •         
    • tom
    •     
        <script> var ul = document.querySelector("ul"); ul.removeChild(ul.children[2]); </script>

    Operasi nod JavaScript yang komprehensif dalam satu artikel

    复制节点(克隆节点)

    node.cloneNode ()

    node.cloneNode ()方法返回调用该方法的节点的一个副本。也称为克隆节点/拷贝节点
    1.如果括号参数为空或者为 false ,则是浅拷贝,即只克隆复制节点本身,不克降里面的子节点。
    2.如果括号参数为 true ,则是深度拷贝,会复制节点本身以及里面所有的子节点。

         
              
    • aniu
    •         
    • marry
    •         
    • tom
    •     
        <script> var ul = document.querySelector("ul"); var li1 = ul.children[0].cloneNode(); //浅拷贝 var li2 = ul.children[0].cloneNode(true); //深拷贝 ul.appendChild(li1); ul.appendChild(li2); </script>

    Operasi nod JavaScript yang komprehensif dalam satu artikel

    【相关推荐:javascript视频教程web前端

    Atas ialah kandungan terperinci Operasi nod JavaScript yang komprehensif dalam satu artikel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

    Kenyataan:
    Artikel ini dikembalikan pada:csdn.net. Jika ada pelanggaran, sila hubungi admin@php.cn Padam