JS DOM中getElement系列和querySelector系列獲取節點

来源:https://www.cnblogs.com/chenyingying0/archive/2020/02/07/12272819.html
-Advertisement-
Play Games

節點查找方法 document.getElementById() 前面必須是document document.getElementsByName() 前面必須是document ele.getElementsByTagName() 前面元素不限 ele.getElementsByClassName ...


節點查找方法

document.getElementById() 前面必須是document

document.getElementsByName()  前面必須是document

ele.getElementsByTagName() 前面元素不限

ele.getElementsByClassName() 前面元素不限

querySelector()

querySelectorAll()


 

.tagName 元素名稱

在低版本IE中,document.getElementById() 存在bug

用來獲取id或者name為指定值的元素

如果某個元素的name屬性值和另一個元素的id屬性值相同

會根據順序選取排在前面的元素

識別IE瀏覽器:在IE瀏覽器中,\V會解析成V;其他瀏覽器中,\V為垂直製表符(相當於空格)

!+"\v1"  在IE中:!+"\v1"=!+"v1"=!NaN=true;其他瀏覽器中:!+"\v1"=!+" 1"=!1=false

document.all是頁面內所有元素的集合

document.all(0) 獲取第一個元素

document.all[0] 獲取第一個元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            var div=document.getElementById("div1");
            console.log(div.tagName);

            //var myul=div.getElementById("myul");
            //console.log(myul);//index.html:19 Uncaught TypeError: div.getElementById is not a function at HTMLDocument.<anonymous> (index.html:19)  說明不能使用其他元素來獲取某個id的元素

            var target=document.getElementById("target");
            console.log(target.innerHTML);//IE7以下:這是錯誤的元素  其他瀏覽器:這是正確的元素

            // 相容低版本IE的寫法
            function getElementById(id){
                var el=document.getElementById(id);
                //如果是IE瀏覽器
                if(!+"\v1"){
                    // 如果獲取到的元素的id就是指定id,則直接返回
                    if(el && el.id===id){
                        return el;
                    }else{
                        var els=document.all(id);
                        var len=els.length;
                        for(var i=0;i<len;i++){
                            if(els[i].id===id){
                                return els[i];
                            }
                        }
                    }
                }
                //如果是其他瀏覽器
                return el;
            }

            console.log(getElementById("target").tagName);//p
        });

    </script>
</head>
<body>
    <a href="#" name="target">這是錯誤的元素</a>
    <p id="target">這是正確的元素</p>

    <div id="div1">
        <ul id="myul">
            <li>1</li>
            <li>2</li>
            <li>3</li>
        </ul>
    </div>
</body>
</html>

 

 

 document.getElementsByName() 在低版本瀏覽器上存在Bug

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            var cbox=document.getElementsByName("num");
            console.log(cbox.length);//3
            console.log(cbox);//NodeList(3) [input, input, input]

        });

    </script>
</head>
<body>
    <input type="checkbox" name="num">1
    <input type="checkbox" name="num">2
    <input type="checkbox" name="num">3
</body>
</html>

document.getElementsByTagName("!") 可以獲取到所有的註釋

.nodeValue() 顯示註釋文本

獲取註釋在谷歌瀏覽器中無法獲取到,只在IE8以下存在

document.getElementsByTagName("*")  獲取到所有的元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            var input=document.getElementsByTagName("input");
            console.log(input[0].value);//hh~

            var comments=document.getElementsByTagName("!");
            var len=comments.length;
            for(var i=0;i<len;i++){
                console.log(comments[i].nodeValue);
            }

            var all=document.getElementsByTagName("*");
            var len=all.length;
            for(var i=0;i<len;i++){
                console.log(all[i].tagName);
            }
        });

    </script>
</head>
<body>
    <!-- 這是一段註釋哈 -->
    <input type="text" value="hh~">
</body>
</html>

 

 

 getElementsByClassName()

相容性IE9+

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            var lights=document.getElementsByClassName("light");
            console.log(lights);//HTMLCollection(3) [div.light, div.light.dark, div.light]

            var light_dark=document.getElementsByClassName("light dark");
            console.log(light_dark);//HTMLCollection [div.light.dark]
        });

    </script>
</head>
<body>
    <div class="light"></div>
    <div class="light dark"></div>
    <div class="light"></div>
</body>
</html>

由於document.getElementsByClassName() 不相容IE8以下的瀏覽器,因此使用document.getElementsByTagName()

以下是相容性寫法

正則中\s表示空白

pattern.test(str) 正則檢測

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            // 自定義相容IE8以下的方法
            var getElementsByClassName=function(opts){
                // 把參數都存儲到一個對象中,使用對象的屬性分別獲取到這些參數
                var searchClass=opts.searchClass;
                var tag=opts.tag || "*";//沒有指定標簽名,則查找所有標簽
                var node=opts.node || document;//沒有指定查找範圍,則查找整個文檔
                var res=[];

                //如果是現代瀏覽器
                if(document.getElementsByClassName){
                    var nodes=node.getElementsByClassName(searchClass);
                    // 判斷是否是指定標簽名
                    if(tag !== "*"){
                        for(var i=0,len=nodes.length;i<len;i++){
                            if(nodes[i].tagName==tag.toUpperCase()){
                                res.push(nodes[i]);
                            }
                        }
                    }else{
                        res=nodes;
                    }
                    return res;
                }else{
                    //如果是IE8以下的瀏覽器
                    var els=node.getElementsByTagName(tag);
                    var len=els.length;
                    // 正則: 開始|空格  +   class  +  結束|空格
                    var pattern=new RegExp("(^|\\s)"+searchClass+"($|\\s)");
                    for(var i=0,j=0;i<len;i++){
                        if(pattern.test(els[i].className)){
                            res[j]=els[i];//將匹配到的數據存儲到res中
                            j++;
                        }
                    }
                    return res;
                }

            }

            // 調用方法
            var node=document.getElementById("box2");
            var res=getElementsByClassName({
                searchClass:"light dark",
                node:node
            });
            console.log(res[0].innerHTML);//1

        });

    </script>
</head>
<body>
    <div id="box1">
        <div class="light">light</div>
        <div class="light dark">light dark</div>
        <div class="light">light</div>
    </div>
    <div id="box2">
        <div class="light">light2</div>
        <div class="light dark">light dark2</div>
        <div class="light">light2</div>
    </div>

</body>
</html>

 

 querySelector()  querySelectorAll()  相容性:IE8+

 querySelector() 找到一個就返回

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){
            
            var box1=document.querySelector("#box1");
            console.log(box1.tagName);//UL

            var li=box1.querySelector("li:last-child");
            console.log(li.innerHTML);//light

            // 類名不規範
            //var boxh=document.querySelector(".hh:bb");//index.html:22 Uncaught DOMException: Failed to execute 'querySelector' on 'Document': '.hh:bb' is not a valid selector.
            //console.log(boxh);
            // 需要進行轉義
            var boxh=document.querySelector(".hh\\:bb");
            console.log(boxh);//<ul id="box1" class="hh:bb">...

            var all=document.querySelectorAll("ul,input");
            console.log(all);//NodeList(3) [ul#box1.hh:bb, ul#box2, input]

        });

    </script>
</head>
<body>
    <ul id="box1" class="hh:bb">
        <li class="light">light</li>
        <li class="light dark">light dark</li>
        <li class="light">light</li>
    </ul>
    <ul id="box2">
        <li class="light">light2</li>
        <li class="light dark">light dark2</li>
        <li class="light">light2</li>
    </ul>
    <input type="text" value="1">

</body>
</html>

之前提到類數組對象具有動態性,但querySelectorAll() 返回的是staticNodeList,不具有動態性

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        body{
            width:100%;
            height:100%;
        }
    </style>
    <script src="DomReady.js"></script>
    <script>
        myReady(function(){

            // 不再陷入死迴圈
            // 因為querySelec

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 操作節點的方法 appendChild() insertBefore() replaceChild() cloneNode() normalize() splitText() sppendChild() 追加子元素 .firstElementChild() 第一個子元素節點 返回值是被操作的那個子節 ...
  • Vue之計算屬性Computed和屬性監聽Watch,Computed和Watch的區別 ...
  • 如何使用css隱藏滾動條 如何隱藏滾動條,同時仍然可以在任何元素上滾動?首先,如果需要隱藏滾動條併在內容溢出時顯示滾動條,只需要設置overflow:auto樣式即可。想要完全隱藏滾動條只需設置overflow:hidden即可,但是這樣一來將導致元素內容不可滾動。時至今日,還沒有任何一條CSS規則 ...
  • 根據下標更改時 常規更改 splice方法 實例 例子 1 在本例中,我們將創建一個新數組,並向其添加一個元素: 輸出: 例子 2 在本例中我們將刪除位於 index 2 的元素,並添加一個新元素來替代被刪除的元素: 輸出: 例子 3 在本例中我們將刪除從 index 2 ("Thomas") 開始 ...
  • import: html文件中,通過script標簽引入js文件。 而vue中,通過import xxx from xxx路徑的方式導入文件,不光可以導入js文件。 “xxx”指的是為導入的文件起一個名稱,不是指導入的文件的名稱,相當於變數名。 “xxx路徑”指的是文件的相對路徑. src下有com ...
  • 今天再重新配置老項目node打包環境的時候遇到了一個問題。 在打包的時候報: (這裡需要強調一下,安裝環境的使用一定要 save dev或者是 save,否則欲哭無淚啊) 很明顯,這是node一些包的版本對應不上的問題。。。 站在巨人的肩膀上摘蘋果: 原文:https://blog.csdn.net ...
  • vue ls NPM Yarn Usage Vue storage API. Global Context API Vue.ls.get(name, def) Vue.ls.set(name, value, expire) Vue.ls.remove(name) Vue.ls.clear() Vue ...
  • Vue使用import ... from ...來導入組件,庫,變數等。而from後的來源可以是js,vue,json。這個是在webpack.base.conf.js中設置的: 這裡的extensions指定了from後可導入的文件類型。 而上面定義的這3類可導入文件,js和vue是可以省略尾碼的 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...