Web前端基礎(11):JavaScript(五)

来源:https://www.cnblogs.com/liuhui0308/archive/2019/11/18/11882650.html
-Advertisement-
Play Games

1. 初識DOM 1.1 DOM介紹 1.1.3 什麼是DOM DOM:文檔對象模型。DOM 為文檔提供了結構化表示,並定義瞭如何通過腳本來訪問文檔結構。目的其實就是為了能讓js操作html元素而制定的一個規範。 DOM就是由節點組成的。 1.1.2 解析過程 HTML載入完畢,渲染引擎會在記憶體中把 ...


1. 初識DOM

1.1 DOM介紹

1.1.3 什麼是DOM

DOM:文檔對象模型。DOM 為文檔提供了結構化表示,並定義瞭如何通過腳本來訪問文檔結構。目的其實就是為了能讓js操作html元素而制定的一個規範。

DOM就是由節點組成的。

1.1.2 解析過程

HTML載入完畢,渲染引擎會在記憶體中把HTML文檔,生成一個DOM樹,getElementById是獲取內中DOM上的元素節點。然後操作的時候修改的是該元素的屬性。 

1.1.3 DOM樹(一切都是節點)

DOM的數據結構如下:

 

上圖可知,在HTML當中,一切都是節點:

元素節點:HMTL標簽。

文本節點:標簽中的文字(比如標簽之間的空格、換行)。

屬性節點:標簽的屬性。

整個html文檔就是一個文檔節點。所有的節點都是Object。

1.1.4 DOM可以做什麼

找對象(元素節點)

設置元素的屬性值

設置元素的樣式

動態創建和刪除元素

事件的觸發響應:事件源、事件、事件的驅動程式

1.2 DOM節點的獲取

DOM節點的獲取方式其實就是獲取事件源的方式

操作元素節點,必須首先找到該節點。有三種方式可以獲取DOM節點:

var div1 = document.getElementById("box1");      //方式一:通過id獲取單個標簽

var arr1 = document.getElementsByTagName("div1");     //方式二:通過 標簽名 獲得 標簽數組,所以有s

var arr2 = document.getElementsByClassName("hehe");  //方式三:通過 類名 獲得 標簽數組,所以有s

既然方式二、方式三獲取的是標簽數組,那麼習慣性是先遍歷之後再使用。

特殊情況:數組中的值只有1個。即便如此,這一個值也是包在數組裡的。這個值的獲取方式如下:

document.getElementsByTagName("div1")[0];    //取數組中的第一個元素

document.getElementsByClassName("hehe")[0];  //取數組中的第一個元素

1.3 DOM訪問關係的獲取

DOM的節點並不是孤立的,因此可以通過DOM節點之間的相對關係對它們進行訪問。如下:

 

節點的訪問關係,是以屬性的方式存在的。

JS中的父子兄訪問關係:

 

這裡我們要重點知道parentNode和children這兩個屬性的用法。下麵分別介紹。 

1.3.1 獲取父節點

調用者就是節點。一個節點只有一個父節點,調用方式就是:

節點.parentNode

(1) nextSibling

指的是下一個節點(包括標簽、空文檔和換行節點)

火狐、谷歌、IE9+版本:都指的是下一個節點(包括標簽、空文檔和換行節點)。

IE678版本:指下一個元素節點(標簽)。

(2) nextElementSibling

火狐、谷歌、IE9+版本:都指的是下一個元素節點(標簽)。

總結:為了獲取下一個元素節點,我們可以這樣做:在IE678中用nextSibling,在火狐谷歌IE9+以後用nextElementSibling,於是,綜合這兩個屬性,可以這樣寫:

下一個兄弟節點 = 節點.nextElementSibling || 節點.nextSibling

previous的中文是: 前一個

 (1) previousSibling

火狐、谷歌、IE9+版本:都指的是前一個節點(包括標簽、空文檔和換行節點)。

IE678版本:指前一個元素節點(標簽)。

(2) previousElementSibling

火狐、谷歌、IE9+版本:都指的是前一個元素節點(標簽)。

總結:為了獲取前一個元素節點,我們可以這樣做:在IE678中用previousSibling,在火狐谷歌IE9+以後用previousElementSibling,於是,綜合這兩個屬性,可以這樣寫:

前一個兄弟節點 = 節點.previousElementSibling || 節點.previousSibling

獲得任意一個兄弟節點:

節點自己.parentNode.children[index];  //隨意得到兄弟節點

1.3.2 獲取單個的子節點

(1) 第一個子節點 | 第一個子元素節點

1.firstChild:

火狐、谷歌、IE9+版本:都指的是第一個子節點(包括標簽、空文檔和換行節點)。

IE678版本:指第一個子元素節點(標簽)。

2.firstElementChild

火狐、谷歌、IE9+版本:都指的是第一個子元素節點(標簽)。

總結:為了獲取第一個子元素節點,我們可以這樣做:在IE678中用firstChild,在火狐谷歌IE9+以後用firstElementChild,於是,綜合這兩個屬性,可以這樣寫:

第一個子元素節點 = 節點.firstElementChild || 節點.firstChild

(2) 最後一個子節點 | 最後一個子元素節點 

1.lastChild 

火狐、谷歌、IE9+版本:都指的是最後一個子節點(包括標簽、空文檔和換行節點)。

IE678版本:指最後一個子元素節點(標簽)。

2.lastElementChild

火狐、谷歌、IE9+版本:都指的是最後一個子元素節點(標簽)。 

總結:為了獲取最後一個子元素節點,我們可以這樣做:在IE678中用lastChild,在火狐谷歌IE9+以後用lastElementChild,於是,綜合這兩個屬性,可以這樣寫: 

 最後一個子元素節點 = 節點.lastElementChild || 節點.lastChild

1.3.3 獲取所有的子節點

1.childNodes:標準屬性。返回的是指定元素的子節點的集合(包括元素節點、所有屬性、文本節點)。是W3C的親兒子。

火狐、谷歌等高本版會把換行也看做是子節點。

用法:

子節點數組 = 父節點.childNodes;   //獲取所有節點。

2.children:非標準屬性。返回的是指定元素的子元素節點的集合。

它只返回HTML節點,甚至不返迴文本節點。

在IE6/7/8中包含註釋節點(在IE678中,註釋節點不要寫在裡面)。

雖然不是標準的DOM屬性,但它和innerHTML方法一樣,得到了幾乎所有瀏覽器的支持。

用法:

子節點數組 = 父節點.children;   //獲取所有節點。用的最多。

1.4 DOM節點操作

上一段的內容:節點的訪問關係都是屬性。

節點的操作都是函數(方法)

1.4.1 創建節點

格式如下:

新的標簽(元素節點) = document.createElement("標簽名");

比如,如果我們想創建一個li標簽,或者是創建一個不存在的adbc標簽,可以這樣做:

<script type="text/javascript">
    var a1 = document.createElement("li");   //創建一個li標簽
    var a2 = document.createElement("adbc");   //創建一個不存在的標簽

    console.log(a1);
    console.log(a2);

    console.log(typeof a1);
    console.log(typeof a2);
</script>

結果:

 

1.4.2 插入節點

插入節點有兩種方式,它們的含義是不同的。

方式1:

父節點.appendChild(新的子節點);

解釋:父節點的最後插入一個新的子節點。

方式2:

父節點.insertBefore(新的子節點,作為參考的子節點);

解釋:

在參考節點前插入一個新的節點。

如果參考節點為null,那麼他將在父節點最後插入一個子節點。

1.4.3 刪除節點

格式如下:

父節點.removeChild(子節點);

解釋:用父節點刪除子節點。必須要指定是刪除哪個子節點。

如果我想刪除自己這個節點,可以這麼做:

node1.parentNode.removeChild(node1);

1.4.4 複製節點

格式如下:

要複製的節點.cloneNode();       //括弧里不帶參數和帶參數false,效果是一樣的。

要複製的節點.cloneNode(true);

括弧裡帶不帶參數,效果是不同的。解釋如下:

不帶參數/帶參數false:只複製節點本身,不複製子節點。

帶參數true:既複製節點本身,也複製其所有的子節點。

1.5 設置節點的屬性 

我們可以獲取節點的屬性值、設置節點的屬性值、刪除節點的屬性。

我們就統一拿下麵這個標簽來舉例:

<img src="images/1.jpg" class="image-box" title="美女圖片" alt="地鐵一瞥" id="a1">

下麵分別介紹。

1.5.1 獲取節點的屬性值

方式1:

元素節點.屬性;
元素節點[屬性];

舉例:(獲取節點的屬性值)

<body>
<img src="images/1.jpg" class="image-box" title="美女圖片" alt="地鐵一瞥" id="a1">

<script type="text/javascript">
    var myNode = document.getElementsByTagName("img")[0];

    console.log(myNode.src);
    console.log(myNode.className);    //註意,是className,不是class
    console.log(myNode.title);

    console.log("------------");

    console.log(myNode["src"]);
    console.log(myNode["className"]); //註意,是className,不是class
    console.log(myNode["title"]);
</script>
</body>

方式2:

素節點.getAttribute("屬性名稱");

例子:

console.log(myNode.getAttribute("src"));
console.log(myNode.getAttribute("class"));   //註意是class,不是className
console.log(myNode.getAttribute("title"));

方式1和方式2的區別在於:前者是直接操作標簽,後者是把標簽作為DOM節點。推薦方式2。

1.5.2 設置節點的屬性值

方式1舉例:(設置節點的屬性值)

myNode.src = "images/2.jpg"   //修改src的屬性值
myNode.className = "image2-box";  //修改class的name

方式2:

元素節點.setAttribute(屬性名, 新的屬性值);

例子:

myNode.setAttribute("src","images/3.jpg");
myNode.setAttribute("class","image3-box");
myNode.setAttribute("id","你好");

1.5.3 刪除節點的屬性

格式:

元素節點.removeAttribute(屬性名);

例子:

myNode.removeAttribute("class");
myNode.removeAttribute("id");

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

-Advertisement-
Play Games
更多相關文章
  • 1. jQuery選擇器 jQuery選擇器是jQuery強大的體現,它提供了一組方法,讓我們更加方便的獲取到頁面中的元素。 1.1 基本選擇器 例子如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>< ...
  • CSS3的新特性 1. 新增CSS3特性有相容性問題,ie9+才支持 2. 移動端支持優於PC端 3. 新增選擇器和盒子模型以及其他特性 4. CSS新增選擇器 屬性選擇器 屬性選擇器可以根據元素特定屬性來選擇元素,這樣就可以不用藉助於類或者id選擇器 | 選擇符 | 簡介 | | | | | E[ ...
  • 1. jQuery概述 1.1 為什麼要使用jQuery 在用js寫代碼時,會遇到一些問題: window.onload 事件有事件覆蓋的問題,因此只能寫一個事件。 代碼容錯性差。 瀏覽器相容性問題。 書寫很繁瑣,代碼量多。 代碼很亂,各個頁面到處都是。 動畫效果很難實現。 jQuery的出現,可以 ...
  • 示例代碼托管在: "http://www.github.com/dashnowords/blogs" 博客園地址: "《大史住在大前端》原創博文目錄" 華為雲社區地址: "【你要的前端打怪升級指南】" [TOC] 一. 硬體加速相關的幾個概念 之前介紹到了 渲染層的概念,在涉及到硬體加速的話題時,出 ...
  • 需求:使用多張圖片作為頁面的背景圖; 首先需要瞭解background的屬性以及細節知識:https://www.cnblogs.com/chenglj/p/7372996.html background-image:url("1.jpg"),url("2.jpg"),url("3.jpg"); b ...
  • 一、html概念 1、定義:(Hyper Text Markup Language)超文本標記語言,主要是通過html標記對網頁中的文本,圖片,聲音等內容進行描述,同時也可以在文本中包含“超級鏈接”,通過超鏈接實現網頁跳轉。 2、編碼格式: gb2312:國家標準第2312條定義了簡體字元,部分亞裔 ...
  • 1. BOM JavaScript基礎分為三部分: ECMAScript:JavaScript的語法標準。包括變數、表達式、運算符、函數、if語句、for語句等。 DOM:文檔對象模型,操作網頁上的元素的API。比如讓盒子移動、變色、輪播圖等。 BOM:瀏覽器對象模型,操作瀏覽器部分功能的API。比 ...
  • 1. JS中的面向對象 創建對象的幾種常用方法: 1.使用Object或對象字面量創建對象 2.工廠模式創建對象 3.構造函數模式創建對象 4.原型模式創建對象 1.1 使用Object或對象字面量創建對象 JS中最基本創建對象的方式: var student = new Object(); stu ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...