ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript での DOM ノード ナビゲーションの詳細な説明

JavaScript での DOM ノード ナビゲーションの詳細な説明

藏色散人
リリース: 2022-08-06 16:49:56
転載
1695 人が閲覧しました

この記事では、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=&#39;p1&#39;>文本节点</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(&#39;p&#39;).parentNode);
        console.log(document.querySelector(&#39;p&#39;).parentNode.attributes[0]);
        console.log(document.querySelector(&#39;p&#39;).parentNode.nodeName); //DIV
        console.log(document.querySelector(&#39;p&#39;).parentNode.nodeValue); //null
        console.log(document.querySelector(&#39;p&#39;).parentNode.nodeType); //1 元素节点
        // 2.通过childNodes获取第一个p
        console.log(document.querySelector(&#39;div&#39;).childNodes[1]);
        console.log(document.querySelector(&#39;div&#39;).childNodes[1].firstChild.nodeName);
        console.log(document.querySelector(&#39;div&#39;).childNodes[1].firstChild.nodeType); //2 文本节点
        console.log(document.querySelector(&#39;div&#39;).childNodes[1].firstChild.nodeValue);
        // 3.firstChild获取main中的第一个子节点
        console.log(document.querySelector(&#39;main&#39;).firstChild);
        // 4.lastChild获取main中的最后一个子节点
        console.log(document.querySelector(&#39;main&#39;).lastChild);
        // 5.nextSibling获取相邻下一个兄弟元素
        console.log(document.querySelector(&#39;#li4&#39;).nextSibling.nextSibling);
        // 6.previousSibling获取相邻上一个兄弟元素
        console.log(document.querySelector(&#39;#li4&#39;).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(&#39;div&#39;).childNodes);
        console.log(document.querySelector(&#39;div&#39;).childNodes.length);
        // 获取子元素节点
        console.log(document.querySelector(&#39;div&#39;).children);
        console.log(document.querySelector(&#39;div&#39;).children[1]);
        console.log(document.querySelector(&#39;div&#39;).firstElementChild);
        console.log(document.querySelector(&#39;div&#39;).firstElementChild.nextElementSibling);
        console.log(document.querySelector(&#39;div&#39;).lastElementChild);
        console.log(document.querySelector(&#39;div&#39;).lastElementChild.previousElementSibling);
        console.log(document.querySelector(&#39;div&#39;).children[1].parentElement);
    </script>
</body>
 
</html>
ログイン後にコピー

関連する推奨事項: [

JavaScript ビデオ チュートリアル

]

以上がJavaScript での DOM ノード ナビゲーションの詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:csdn.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート