成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript 一些 DOM 的知識點

tommego / 1889人閱讀

摘要:判斷傳入的節(jié)點是否是調(diào)用該方法的節(jié)點的后代節(jié)點。范圍對象表示一個包含節(jié)點和部分文本節(jié)點的文檔片段返回一個對象這個也是簡單提一下,以后用到了再補。

JavaScript 一些 DOM 的知識點

原文鏈接/)

本來準備把 DOM 的接口都總結(jié)一遍,但是我太天真了,DOM 下面的接口太龐大了,總結(jié)起來太費時了,所以只將自己平時沒注意到的以及常用到的知識記下來了,更詳細的 DOM 還是看 MDN 上的資料吧!

Node 接口

Node 是一個接口,該接口由 DOM 中的所有的節(jié)點類型實現(xiàn),即所有節(jié)點類型(比如最常見的 Element 類型)都繼承自 Node 接口。

本來,節(jié)點類型總共有12種,但是隨著 DOM4 的出現(xiàn),有 5 種節(jié)點類型被棄用。(詳情看這里)

Node 接口的很多屬性(比如 childNodes 、lastChild、firstChild、nextSibling、previousSibling)針對的是所有的節(jié)點類型,并不只是元素節(jié)點。

document.body.childNodes;

在瀏覽器控制端輸入上面的代碼,你會看到顯示的結(jié)果不僅僅有元素節(jié)點,還可能有文本節(jié)點、注釋節(jié)點等!

Node.hasChildNodes():檢測一個節(jié)點下面是否包含一個或多個節(jié)點,若是,則返回 true。

Node.contains(otherNode):判斷傳入的節(jié)點是否是調(diào)用該方法的節(jié)點的后代節(jié)點。

Document 類型(文檔節(jié)點)

JavaScript 通過 Document 類型表示文檔。document 對象是 window 對象的一個屬性。

一些 document 對象的屬性:

document.documentElement // 指向 html 元素
document.head            // 指向 head 元素(HTML 5 新增)
document.body            // 指向 body 元素

document.characterSet    // 取得文檔使用的字符集
document.title           // 取得或設(shè)置文檔的標(biāo)題

document.URL             // 取得文檔完整的 URL
document.domain          // 取得文檔所在的域名
Element 類型(元素節(jié)點)

Element 類型節(jié)點的 nodeType 的值為 1,nodeName 的值為元素的標(biāo)簽名。

有關(guān) Element類型節(jié)點的特性

獲取或設(shè)置公認的特性一般直接使用 對應(yīng)的屬性

獲取或設(shè)置自定義特性,使用 getAttribute()、setAttribute() 方法

根據(jù) HTML5 規(guī)范,自定義特性應(yīng)該加上 data- 前綴以便驗證

// HTML 代碼
Some text
// js 代碼,運行于瀏覽器控制端 var ele = document.getElementById("container"); ele.id; // "container" ele["id"]; // "container" ele.className; // "class1 class2" ele.title; // "titleValue" ele.className += " class3"; // 更改 class 的值 ele.className; // "class1 class2 class3" // 利用 setAttribute() 可以添加元素不存在的特性 ele.setAttribute("data-test","just test"); // 添加自定義特性 ele["data-test"]; // undefined,不能直接訪問自定義特性 ele.getAttribute("data-test"); // "just test" ele.removeAttribute("class"); // 刪除 class 特性 ele.className; // "",一個空字符串

classList 屬性

這個屬性是 HTML5 中新增的用來操作元素類名的屬性。它比 className 屬性使用起來更方便。這個屬性返回的是一個新集合類型 DOMTokenList 的實例,它也是一個類數(shù)組對象。

var ele = document.getElementById("container"); ele.classList; // ["class1", "class2"] ele.classList[0]; // "class1" string 類型 ele.classList.length; // 2 ele.classList.add("class3"); // 添加新類名 ele.classList.remove("class1"); // 刪除類名 ele.classList; // ["class2", "class3"] // contains() 用來檢測是否某個類名 ele.classList.contains("class1"); // false ele.classList.contains("class2"); // true // toggle() 用來交替刪除添加某個類名 ele.classList.toggle("class4"); // 不存在,則添加 ele.classList; // ["class2", "class3", "class4"] ele.classList.toggle("class4"); // 存在,則刪除 ele.classList; // ["class2", "class3"]

attributes 屬性:返回一個 NamedNodeMap 類數(shù)組對象,它不能使用數(shù)組的方法。

一般不使用這個屬性,除非用來遍歷元素的特性。

// 繼續(xù)上面的代碼
ele.attributes;  // NamedNodeMap {0: id, 1: title, 2: data-test, length: 3}

ele.attributes[0].nodeName;   // "id"
ele.attributes[0].nodeValue;  // "container"

document.createElement():創(chuàng)建新元素節(jié)點

var div = document.createElement("div");
console.log(div);         // 
console.log(typeof div); // object div.id = "container"; div.className = "a b c"; console.log(div); //

元素遍歷

我們前面說過,某個元素節(jié)點的 childNodes 屬性返回的集合可能會包含注釋節(jié)點、文本節(jié)點等我們一般不會去操作的節(jié)點,我們想要的只是元素節(jié)點。所以我們可以用下面的方法來達到我們的目的:

// 原理:通過 if 條件語句過濾掉不是元素節(jié)點的其它節(jié)點

var ele = document.getElementById("container");
var len = ele.childNodes.length;
for(let i = 0; i < len; i++){
  if(ele.childNodes[i].nodeType === 1){
    // 執(zhí)行一些操作
    ele.childNodes[i].style.color = "green";
  }
}

很幸運,現(xiàn)在,W3C 已經(jīng)幫我們搞出了一些新的屬性來專門操作元素節(jié)點。

Element.children:返回一個該元素下所有子元素節(jié)點的集合

Element.firstElementChild:返回第一個子元素節(jié)點

Element.lastElementChild:返回最后一個子元素節(jié)點

Element.previousElementSibling:返回前一個同輩元素節(jié)點

Element.nextElementSibling:返回后一個同輩元素節(jié)點

插入標(biāo)記

innerHTML:返回或更改調(diào)用它的節(jié)點的所有子節(jié)點(包括注釋節(jié)點、文本節(jié)點等)

outerHTML:返回或更改調(diào)用它的元素以及這個元素所有的子節(jié)點

上面兩種屬性返回的都是字符串

element.insertAdjacentHTML(position, text):將指定的文本解析為 HTML 或 XML,然后將結(jié)果節(jié)點插入到指定的位置上

position 是相對于 element 元素的位置,并且它有四個值

beforebegin:在 element 元素之前插入一個緊鄰的同輩元素

afterbegin:在 element 元素的第一個子節(jié)點之前插入

beforeend:在 element 元素的最后一個節(jié)點之后插入

afterend:在 element 元素之后插入一個緊鄰的同輩元素

Text 類型(文本節(jié)點)

Text 類型的節(jié)點(文本節(jié)點)的 nodeType 的值為 3。

document.createTextNode("文本內(nèi)容"):創(chuàng)建新文本節(jié)點

規(guī)范化文本節(jié)點

DOM 文檔中存在相鄰的文本節(jié)點很容易導(dǎo)致混亂,因為分不清哪個文本節(jié)點表示哪個字符串。所以在 Node 接口中定義了一個 normalize() 方法,用來將當(dāng)前節(jié)點和它的后代節(jié)點規(guī)范化。在一個"規(guī)范化"后的DOM樹中,不存在一個空的文本節(jié)點,或者兩個相鄰的文本節(jié)點。

var ele = document.createElement("div");

var textNode = document.createTextNode("Hello ");
ele.appendChild(textNode);
var anotherTextNode = document.createTextNode("world!");
ele.appendChild(anotherTextNode);

document.body.appendChild(ele);

console.log(ele.childNodes.length);   // 2
ele.normalize();                      // 規(guī)范化文本節(jié)點
console.log(ele.childNodes.length);   // 1

innerText 屬性:取得或更改操作元素包含的所有文本內(nèi)容

Comment 類型(注釋節(jié)點)

一般不會去操作注釋節(jié)點!

// 注釋節(jié)點是 div 元素的一個子節(jié)點

document.createComment():創(chuàng)建一個注釋節(jié)點

選擇符 API

Selector API 是由 W3C 發(fā)起制定的一個標(biāo)準,致力于讓瀏覽器原生 JavaScript 支持 CSS 查詢。

Selectors API Level 1 的核心是兩個方法:querySelector()querySelectorAll()。

// selectors 是一個 CSS 選擇器字符串

// 從整個文檔開始查找
Document.querySelector(selectors)
Document.querySelectorAll(selectors)

// 從 Element 元素的后代元素開始查找
Element.querySelector(selectors)
Element.querySelectorAll(selectors)
文檔模式(document mode)

Doctype 是 Document Type (文檔類型)的簡寫,用來說明你用的XHTML或者HTML是什么版本。它的作用是告知瀏覽器的解析器,用什么文檔類型規(guī)范來解析這個文檔。

文檔模式用于指定IE的頁面排版引擎(Trident)以哪個版本的方式來解析并渲染網(wǎng)頁代碼

document.compatMode:檢測當(dāng)前文檔的渲染模式

若值為 BackCompat,則為混雜模式

若值為 CSS1Compat,則為標(biāo)準規(guī)范模式

document.documentMode:檢測 IE 瀏覽器是在哪個瀏覽器模式下(這個屬性只適用于 IE 瀏覽器)

參考:文檔解析——Doctype、嚴格&混雜模式、瀏覽器&文檔模式

DOM2 樣式

HTMLElement.style:返回一個 CSSStyleDeclaration 對象,表示元素的內(nèi)嵌 style 屬性。

這個屬性的返回值只包含了在元素內(nèi)嵌 style 屬性上聲明的的 CSS 屬性,而不包括來自其他地方聲明的樣式(比如 head 部分聲明的 CSS 屬性)。

由于 style 屬性的優(yōu)先級和通過 style 設(shè)置元素的內(nèi)聯(lián)樣式是一樣的,并且在css層級樣式中擁有最高優(yōu)先級,因此在為特定的元素設(shè)置樣式時很有用。

// 為元素添加 2 個內(nèi)嵌的 CSS 規(guī)則
var ele = document.getElementById("container");

// 方法一
ele.setAttribute("style","font-size:2em;color:green");  
// 方法二
ele.style.cssText = "font-size:2em;color:green";
// 方法三
var sty = ele.style;
sty.fontSize = "2em";
sty.color = "green";

DOM Level 2 Style: ElementCSSInlineStyle.style()

要獲取一個元素的所有 CSS 屬性,你應(yīng)該使用 window.getComputedStyle()

// 單純地調(diào)用這個方法,會和上面的 style 屬性一樣返回一個 CSSStyleDeclaration 對象
window.getComputedStyle(ele);

// 該方法返回經(jīng)過疊加計算后的元素的實際樣式
window.getComputedStyle(ele).fontSize;
window.getComputedStyle(ele).color;

document.styleSheets:只讀,返回一個由 StyleSheet 對象組成的 StyleSheetList,每個 StyleSheet 對象都是文檔中鏈接或嵌入的樣式表(即內(nèi)聯(lián)樣式和外聯(lián)樣式,不包括嵌在元素里的樣式)。

// 獲取當(dāng)前文檔中樣式表的數(shù)量
document.styleSheets.length;

// 禁用第一個樣式表
document.styleSheets[0].disabled = true;
DOM2 遍歷

DOM2 中定義了兩個用于輔助完成順序遍歷 DOM 結(jié)構(gòu)的類型:NodeIteratorTreeWalker

document.createNodeIterator():返回一個 NodeIterator 對象

document.createTreeWalker():返回一個 TreeWalker 對象

這里只簡單提一下這兩個方法,因為暫時還沒用過,所以先不展開了,以后用了再補。

DOM2 范圍(range)

Range 對象 表示一個包含節(jié)點和部分文本節(jié)點的文檔片段

document.createRange():返回一個 Range 對象

這個也是簡單提一下,以后用到了再補。

參考資料

【書】《JavaScript 高級程序設(shè)計(第三版)》

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/80380.html

相關(guān)文章

  • 前端練級攻略(第二部分)

    摘要:是文檔的一種表示結(jié)構(gòu)。這些任務(wù)大部分都是基于它。這個實踐的重點是把你在前端練級攻略第部分中學(xué)到的一些東西和結(jié)合起來。一旦你進入框架部分,你將更好地理解并使用它們。到目前為止,你一直在使用進行操作。它是在前端系統(tǒng)像今天這樣復(fù)雜之前編寫的。 本文是 前端練級攻略 第二部分,第一部分請看下面: 前端練級攻略(第一部分) 在第二部分,我們將重點學(xué)習(xí) JavaScript 作為一種獨立的語言,如...

    BWrong 評論0 收藏0
  • [譯] 前端攻略-從路人甲到英雄無敵二:JavaScript 與不斷演化框架

    摘要:一般來說,聲明式編程關(guān)注于發(fā)生了啥,而命令式則同時關(guān)注與咋發(fā)生的。聲明式編程可以較好地解決這個問題,剛才提到的比較麻煩的元素選擇這個動作可以交托給框架或者庫區(qū)處理,這樣就能讓開發(fā)者專注于發(fā)生了啥,這里推薦一波與。 本文翻譯自FreeCodeCamp的from-zero-to-front-end-hero-part。 繼續(xù)譯者的廢話,這篇文章是前端攻略-從路人甲到英雄無敵的下半部分,在...

    roadtogeek 評論0 收藏0
  • 做一名精致JavaScripter 01:JavaScript簡介

    摘要:精致從細節(jié)做起。標(biāo)準會在每年的月發(fā)布一次,作為當(dāng)年的正式版本,便是年發(fā)布的正式版本。支持情況各大瀏覽器對的支持情況瀏覽器支持情況對的支持情況支持情況。在瀏覽器中基于實現(xiàn)的已經(jīng)成為的重要組成部分。 精致從細節(jié)做起。前端的工作也有一段時間了,大大小小的前端框架都有接觸過,越是深入學(xué)習(xí)越是感覺之前的學(xué)習(xí)過于粗糙,基礎(chǔ)不夠扎實,于是準備近期把JavaScript的基礎(chǔ)知識點梳理一下,查缺補漏,...

    張巨偉 評論0 收藏0
  • 【譯】前端練級攻略

    摘要:由于系統(tǒng)變得越來越復(fù)雜,人們提出了稱為預(yù)處理器和后處理器的工具來管理復(fù)雜性。后處理器在由預(yù)處理器手寫或編譯后對應(yīng)用更改。我之前建議的文章,,也涵蓋了預(yù)處理器相關(guān)的知識。 譯者:前端小智 原文:medium.freecodecamp.org/from-zero-t… medium.freecodecamp.org/from-zero-t… 我記得我剛開始學(xué)習(xí)前端開發(fā)的時候。我看到了很多文章及...

    wuyumin 評論0 收藏0
  • 前端性能優(yōu)化之--頁面渲染優(yōu)化全面解析

    摘要:下面我們撇開網(wǎng)絡(luò)方面的優(yōu)化,只分析靜態(tài)資源方面的優(yōu)化。不過,也會阻止的構(gòu)建和延緩網(wǎng)頁渲染。未優(yōu)化正常加載優(yōu)化后異步加載根據(jù)上面的分析,我們可以清楚的認識到,非必要優(yōu)先加載的,選擇異步加載是最優(yōu)選擇。 為什么做優(yōu)化 經(jīng)典問題:白屏?xí)r間過長,用戶體驗差產(chǎn)生的原因:網(wǎng)絡(luò)問題、關(guān)鍵渲染路徑(CRP)問題 怎么做優(yōu)化 如何做好優(yōu)化呢,網(wǎng)上隨便一搜,就有很多優(yōu)化總結(jié),無非就是網(wǎng)絡(luò)優(yōu)化、靜態(tài)資源(h...

    MadPecker 評論0 收藏0

發(fā)表評論

0條評論

tommego

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<