ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript での DOM ノード ナビゲーションの詳細な説明
この記事では、DOM ノードを使用してページ要素を取得する方法を主に紹介します。要素ノード、テキスト ノード、属性ノード、ドキュメント ノード、コメント ノードなど、ページ ドキュメント内のすべてがノードです。以下に、ノードを取得する 2 つの主な方法を紹介します。
(1) ノードの取得 (テキスト ノード、要素ノードなどのすべてのノードを含む)
1.parentNode: 親ノードを取得します。
2.childNodes: 子ノードを取得します。インデックス値を通じて各子ノードを取得します。
3.firstChild: 最初の子ノードを取得します。親ノードの
4.lastChild: 親ノードの最後の子ノードを取得します
5.nextSibling: 子ノードに隣接する次の兄弟ノードを取得します
6 .previousSibling: 隣接する子ノードを取得します。 前の兄弟ノード
#7.attributes: 属性を取得します。 node<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>由节点关系获取元素</title> <style> </style> </head> <body> <div name="div1"> <p name='p1'>文本节点</p> <p>2</p> <ul> <li>3</li> <li id="li4">4</li> <li>5</li> <li>6</li> </ul> </div> <section>7</section> <main><span>8</span><i>9</i></main> <script> //注意换行和空格也属于结点,属于文本节点,按节点关系访问时需要考虑。属性节点无须考虑。 //1. parentNode获取div console.log(document.querySelector('p').parentNode); console.log(document.querySelector('p').parentNode.attributes[0]); console.log(document.querySelector('p').parentNode.nodeName); //DIV console.log(document.querySelector('p').parentNode.nodeValue); //null console.log(document.querySelector('p').parentNode.nodeType); //1 元素节点 // 2.通过childNodes获取第一个p console.log(document.querySelector('div').childNodes[1]); console.log(document.querySelector('div').childNodes[1].firstChild.nodeName); console.log(document.querySelector('div').childNodes[1].firstChild.nodeType); //2 文本节点 console.log(document.querySelector('div').childNodes[1].firstChild.nodeValue); // 3.firstChild获取main中的第一个子节点 console.log(document.querySelector('main').firstChild); // 4.lastChild获取main中的最后一个子节点 console.log(document.querySelector('main').lastChild); // 5.nextSibling获取相邻下一个兄弟元素 console.log(document.querySelector('#li4').nextSibling.nextSibling); // 6.previousSibling获取相邻上一个兄弟元素 console.log(document.querySelector('#li4').previousSibling.previousSibling); // 总结:除parentNode外,其他方法谨慎选择,一旦代码格式有变,就会出现错误 // 通过nodeName获取节点名称 //通过nodeValue获取节点值 // 通过nodeType返回节点类型 </script> </body> </html>
(2) 要素ノードを取得します。
1.parentElement: 親要素ノードを取得します。 2.children: 子要素ノードを取得します。インデックス値を通じて各子要素ノードを取得します。##3.firstElementChild: 最初の子要素を取得します。親の要素ノードを取得します。
4.lastElementChild: 親の最後の子要素ノードを取得します。
5.nextElementSibling: 隣接する次の兄弟要素ノードを取得します。node
6.previousElementSibling : 隣接する前の兄弟要素ノードを取得します
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>获取子元素节点</title> </head> <body> <div> <p>123</p> <p>456</p> <p>789</p> </div> <script> //p标签总体算一个节点,内部的“123”不算 console.log(document.querySelector('div').childNodes); console.log(document.querySelector('div').childNodes.length); // 获取子元素节点 console.log(document.querySelector('div').children); console.log(document.querySelector('div').children[1]); console.log(document.querySelector('div').firstElementChild); console.log(document.querySelector('div').firstElementChild.nextElementSibling); console.log(document.querySelector('div').lastElementChild); console.log(document.querySelector('div').lastElementChild.previousElementSibling); console.log(document.querySelector('div').children[1].parentElement); </script> </body> </html>
関連する推奨事項: [
JavaScript ビデオ チュートリアル以上がJavaScript での DOM ノード ナビゲーションの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。