DOM操作之元素查找

来源:https://www.cnblogs.com/haloujava/archive/2023/12/26/17927882.html
-Advertisement-
Play Games

隨著小程式使用場景越發廣泛,用戶體驗愈發受重視,如何通過技術手段提升小程式性能成為重中之重,本篇文章以京東購物小程式性能優化實踐為例,帶您實現性能翻倍! ...


通常我們操作一個元素節點前都需要查找到這個元素,查找到這個元素有兩種方式。

  1. 使用選擇器函數查找元素
  2. 通過元素的關係屬性來查找元素

使用選擇器函數查找

getElementById

通過節點元素的ID得到此節點

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>getElementById</title>
</head>
<body>
    <div id="box">id選擇器</div>
    <div id="boxDiv">boxDiv</div>
    <div id="boxDiv">boxDiv</div>

    <script>
        var box = document.getElementById('box');
        var boxDiv = document.getElementById('boxDiv');
        console.log("box:", box);
        console.log("boxDiv:", boxDiv);
</script>
</body>
</html>

上面的例子中,id = ”boxDiv“ 有重覆,在HTML的規則中, ID在一個網頁應當是唯一的,如果重覆, documen.getElementById 方法也只會獲取第一個。

getElementsByName

通過名稱獲得節點, 返回的是一個數組集合

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <input type="hidden" name="up" />
    <input type="hidden" name="down" />

    <script>
        const up_names = document.getElementsByName("up");
        console.log(up_names);
</script>
</body>
</html>

getElementByTagName

通過標簽名得到一組標簽數組

註意:此方法返回的是數組,即使頁面上只有一個此節點的元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>getElementByTagName</title>
</head>
<body>
    <div>哈嘍,第一</div>
    <div>哈嘍,第二</div>
    <div>哈嘍,第三</div>
    <div>哈嘍,第四</div>

    <div id="divBox">
        <p>段落</p>
        <p>段落</p>
        <p>段落</p>
        <p>段落</p>
    </div>

    <script>
        // 得到一個div標簽的數據
        var divS = document.getElementsByTagName('div');
        console.log(divS);

        var divBox = document.getElementById('divBox');
        var pArray = divBox.getElementsByTagName('p');
        console.log(pArray);
</script>
</body>
</html>

getElementByClassName

通過class選擇器得到元素節點的數組

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>getElementByIdElementByClassName</title>
</head>
<body>

    <div id="box1">
        <p class="child box1Child">box1節點一</p>
        <p class="child box1Child">box1節點二</p>
        <p class="child box1Child">box1節點三</p>
        <p class="child box1Child">box1節點四</p>
    </div>
    <div id="box2">
        <p class="child box2Child">box2節點2</p>
        <p class="child box2Child">box2節點二</p>
        <p class="child box2Child">box2節點三</p>
        <p class="child box2Child">box2節點四</p>
    </div>
    <script>
        
        // 會獲取到所有 包含 class = child 的元素
        var child = document.getElementsByClassName('child');
        console.log('child:',child);

        
        var box1 = document.getElementById('box1');
        
        // 獲取 id 為 box1 下的所有 class = box2Child 的子元素
        var box1Children = box1.getElementsByClassName('box1Child');

        console.log('box1Children:',box1Children);
</script>
</body>
</html>

querySelector

通過選擇器或者選擇器組得到元素節點,只能得到頁面上的一個元素,如果有多個元素符合條件,則只能得到第一個元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>querySelector</title>
</head>
<body>
    <div id="box1">
        <p>子元素</p>
        <p class="child">子元素1</p>
        <p class="child">子元素2</p>
    </div>

    <script>
        // querySelector 多個元素只會獲得第一個
        var child = document.querySelector('#box1 .child');
        console.log('child:', child);
</script>
</body>
</html>

querySelectoryAll

通過選擇器或者選擇器組得到數組元素

註:返回值是一個數組

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>querySelector</title>
</head>
<body>
    <div id="box1">
        <p>子元素</p>
        <p class="child">子元素1</p>
        <p class="child">子元素2</p>
    </div>

    <script>
       
        // 根據元素選擇器獲取所有的子元素
        var children = document.querySelectorAll('#box1 .child');
        console.log('children:', children);
</script>
</body>
</html>
方法 功能
getElmentById 通過ID得到元素
getElementsByName 通過名稱得到元素
getElementByTagName 通過標簽名得到元素數組
getElementByClassName 通過類名得到元素數組
querySelector 通過選擇器得到元素
querySelectoryAll 通過選擇器得到元素數組

關係屬性查找元素

關係屬性查找,是根據已知的節點去查找我們想要的節點

節點和節點組成了一棵樹,有以下幾種角色

父節點:在一個嵌套結構中,外層的被成為內層節點的父節點

子節點:嵌套在父節點內部的節點

兄弟節點:處在同一層級,併列的節點被稱為兄弟節點

<!--id為parentNode被稱為父節點-->
<div id='parentNode'>
  <!--子節點-->
  <div></div>
  <div></div>
</div>
<!--parentNode2 和 parentNode 併列,稱為兄弟節點 -->
<div id='parentNode2'>
<div>

這些角色之間有以下幾種關係,我們就可以用這些關係屬性獲取相應的元素節點

關係 所有節點
子節點 childNodes
父節點 parentNode
第一個子節點 firstChild
最後一個子節點 lastChild
前一個兄弟節點 previousSibling
後一個兄弟節點 nextSlibling

拓展

DOM中,文本和空白也應該算DOM的節點, 所以用上述表格中的屬性取的是所有的節點

在日常開發中,我們可能只需要操作元素節點(帶標簽的)的節點, 因此,有了以下屬性方便我們操作

關係 元素節點
子節點 children
第一個子節點 firstElementChild
最後一個子節點 lastElementChild
前一個兄弟節點 previousElementSibling
後一個兄弟節點 nextElementSibling
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>節點關係</title>
</head>
<body>
    
    <div id="divBox">
        <p>文字文字</p>
        <p class="secondP">文字文字</p>
        <p>文字文字</p>
    </div>
    <script>
        var divBox = document.getElementById('divBox');

        // 列印所有子節點 (包含空文本等也算一個節點)
        console.log(divBox.childNodes);
        // 列印所有元素節點(從IE9開始相容)
        console.log(divBox.children);

        
        // 列印父節點
        var secondP = document.querySelector('.secondP');
        console.log('secondP:', secondP.parentNode);

        // 第一個子節點
        var firstChild = divBox.firstChild;
        console.log('第一個子節點:', firstChild);

        // 第一個子元素節點
        var firstElementChild = divBox.firstElementChild;
        console.log('第一個子元素節點:', firstElementChild);

        // 最後一個子節點
        var lastChild = divBox.lastChild;
        console.log('最後一個子節點:', lastChild);

        // 最後一個元素節點
        var lastElementChild = divBox.lastElementChild;
        console.log('最後一個元素節點:', lastElementChild);

        // 前一個兄弟節點 如果沒有返回null
        var previousSibling = secondP.previousSibling;
        console.log('前一個兄弟節點:', previousSibling);

        // 前一個兄弟元素節點, 如果沒有返回null
        var previousElementSibling = secondP.previousElementSibling;
        console.log('前一個兄弟元素節點:', previousElementSibling);

        // 後一個兄弟節點, 如果沒有返回null
        var nextSibling  = secondP.nextSibling;
        console.log('後一個兄弟節點:', nextSibling);

        // 後一個兄弟元素節點 , 如果沒有返回null
        var nextElementSibling = secondP.nextElementSibling;
        console.log('後一個兄弟元素節點:', nextElementSibling);
</script>
</body>
</html>

上面獲取元素節點的方法相容到IE9, 其實我們可以使用前面文章中提到的 nodeType 來模擬實現 這些方法,這種寫法可以相容到IE6

我們知道 nodeType = 1 的為元素節點,因此我們通過方法模擬實現類似children屬性的功能, 獲取一個元素的所有子節點

以下為實現代碼

<div id="divBox">
        <p>文字文字</p>
        <p class="secondP">文字文字</p>
        <p>文字文字</p>
    </div>
    <script>
        var divBox = document.getElementById('divBox');

        function getChildren(node) {
            // 結果數組
            var children = [];
            // 遍歷node這個節點的所有子節點,判斷每一個子節點的nodeType屬性是不是1
            // 如果時1 , 就推入數組
            for(var i = 0 ; i < node.childNodes.length; i++) {
                if(node.childNodes[i].nodeType == 1) {
                    children.push(node.childNodes[i]);
                }
            }
            return children;
        }
        console.log(getChildren(divBox));
</script>
請關於一下啦^_^

微信公眾號


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

-Advertisement-
Play Games
更多相關文章
  • 路是腳踏出來的,歷史是人寫出來的。人的每一步行動都在書寫自己的歷史。 Linux 基礎命令 open:打開文件操作,如環境配置文件。 open ~/.zshrc vi:vi (visual interface), linux 中最經典的文本編輯器 vim(vi improved)是 vi 發展出來的 ...
  • 在運行程式時有時候會需要查看資源占用,以方便部署在其他伺服器上時進行參考。以下是總結了我在linux上查找程式進程資源的兩種方法(cpu和gpu都有)。 ...
  • 在 Apache Flink 中實現高效的 Top N 數據處理,尤其是涉及時間視窗和多條件排序時,需要精細地控制數據流和狀態管理。 普通計算TopN: 1. 定義數據源(Source) 首先,我們需要定義數據源。這可能是 Kafka 流、文件、資料庫或任何其他支持的數據源。 val stream: ...
  • 在回答這個問題之前,首先我們看看 MySQL 中有哪些常用的 JDBC 連接池: c3p0 DBCP Druid Tomcat JDBC Pool HikariCP 這些連接池中,c3p0 是一個老牌的連接池,很多流行框架,在其老版本中,都將 c3p0 作為預設的連接池。 DBCP 和 Tomcat ...
  • 出現分散式死鎖現象後,如果沒有外部干預,通常是一方等待鎖超時報錯後,事務回滾清理持有鎖資源,另一方可繼續執行。 ...
  • 背景 由於業務變遷,合規要求,我們需要刪除大量非本公司的數據,涉及到上百張表,幾個T的數據清洗。我們的做法是先從基礎數據出發,將要刪除的數據id收集到一張表,然後再由上往下刪除子表,多線程併發處理。 我們使用的是阿裡的polardb,完全相容mysql協議,5.7版本,RC隔離級別。刪除過程一直很順 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 工程化最開始就是package.json開始的,很多人學了很多年也沒搞清楚這個為什麼這麼神奇,其實有些欄位是在特定場景才有效的,那每個屬性的適用場景和作用是什麼,又牽扯很多知識點,今天先解讀一些常見的屬性,關註我,後期在遇到特定場景也會再 ...
  • 本章目標:偵聽器watch是如何相容ref、響應式對象和getter函數等不同數據源的?回調時機immediate是如何實現的?關於onCleanup,一個用於註冊副作用清理的回調函數是如何實現的? ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...