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.
[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.
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.
Secara amnya, nod mempunyai sekurang-kurangnya tiga atribut asas: nodeType (nod type), nodeName (nod name) dan nodeValue (node value).
Dalam pembangunan sebenar kami, operasi nod terutamanya beroperasi pada nod elemen.
Menggunakan pepohon DOM, nod boleh dibahagikan kepada perhubungan hierarki yang berbeza Yang paling biasa ialah perhubungan hierarki antara bapa, anak dan abang.
node.parentNode
<p> </p><p></p> <script> var son = document.querySelector(".son"); console.log(son.parentNode); </script>
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.
Mengapakah terdapat lima nod teks di sini sebenarnya sepadan dengan lima pemisah baris Lihat gambar di bawah:
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.
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.
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,指定元素)
node.removeChild(child)
node.removeChild(child) 方法从DOM中删除一个子节点,返回删除的节点。
node.cloneNode ()
node.cloneNode ()方法返回调用该方法的节点的一个副本。也称为克隆节点/拷贝节点
1.如果括号参数为空或者为 false ,则是浅拷贝,即只克隆复制节点本身,不克降里面的子节点。
2.如果括号参数为 true ,则是深度拷贝,会复制节点本身以及里面所有的子节点。
【相关推荐: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!