《JavaScript DOM 編程藝術(shù)》讀書筆記之DOM基礎(chǔ)
DOM
DOM:文檔對象模型;
節(jié)點(diǎn)
元素節(jié)點(diǎn):DOM的原子是元素節(jié)點(diǎn)。<body>、<p>、<ul>之類的元素。元素可以包含其他的元素。沒有被包含在其他元素里的唯一元素是<html>元素
文本節(jié)點(diǎn):在XHTML文檔里,文本節(jié)點(diǎn)總是被包含在元素節(jié)點(diǎn)的內(nèi)部。
屬性節(jié)點(diǎn):屬性節(jié)點(diǎn)用來對元素做出更具體的描述。例如,幾乎每個(gè)元素都有一個(gè)title屬性,而我們可以利用這個(gè)屬性對包含在元素里的東西作出準(zhǔn)確的描述:
<p title="a gentle reminder">Don't forget to buy this stuff.</p>
在DOM中,title="a gentle reminder"是一個(gè)屬性節(jié)點(diǎn)。
CSS
獲取元素
getElementById, getElementsByTagName, getElementsByClassName三種可以獲取元素節(jié)點(diǎn)的方法。
getElementsByTagName允許把一個(gè)通配符作為它的參數(shù),而這意味著文檔里的每個(gè)元素都將在這個(gè)函數(shù)所返回的數(shù)組里占有一席之地。通配符(“*”)必須在引號里,這是為了和乘法操作有所區(qū)別。
還可以把getElementById和getElementsByTagName結(jié)合起來運(yùn)用。如下所示:
var shopping = document.getElementById("purchase");
var items = shopping.getElementsByTagName("*");
這樣就可以得到id屬性值為purchase的元素包含著多少個(gè)元素。
getElementsByClassName方法只有較新的瀏覽器才支持。為了彌補(bǔ)這一點(diǎn),DOM腳本程序員需要使用已有的DOM方法來實(shí)現(xiàn)自己的getElementsByClassName。而多數(shù)情況下,他們的實(shí)現(xiàn)過程都與下面這個(gè)getElementsByClassName大致相似:
function getElementsByClassName(node, classname){
if(node.getElementsByClassName){
return node.getElementsByClassName(classname);
}else{
var results = new Array();
var elems = node.getElementsByTagName("*");
for(var i=0;i<elems.length;i++){
if(elems[i].className.indexOf(classname) != -1){
results[results.length] = elems[i];
}
}
return results;
}
}
這個(gè)getElementsByClassName函數(shù)接受兩個(gè)參數(shù),第一個(gè)node表示DOM樹中的搜素起點(diǎn),第二個(gè)classname就是要搜索的類名了。
獲取和設(shè)置屬性
getAttribute是一個(gè)函數(shù),它只有一個(gè)參數(shù)——你打算查詢的屬性的名字:
object.getAttribute(attribute)
setAttribute()允許我們對屬性節(jié)點(diǎn)的值做出修改。通過setAttribute對文檔作出修改后,在通過瀏覽器的view source(查看源代碼)選項(xiàng)去查看文檔的源代碼時(shí)看到的仍將是改變前的屬性值,也就是說,setAttribute做出的修改不會反映在文檔本身的源代碼里。這種“表里不一”的現(xiàn)象源自DOM的工作模式:先加載文檔的靜態(tài)內(nèi)容,再動(dòng)態(tài)刷新,動(dòng)態(tài)刷新不影響文檔的靜態(tài)內(nèi)容。這正是DOM的真正威力:對頁面內(nèi)容進(jìn)行刷新卻不需要在瀏覽器里刷新頁面。
相關(guān)文章
JavaScript中window.open用法實(shí)例詳解
這篇文章主要介紹了JavaScript中window.open用法,實(shí)例分析了window.open方法的功能、參數(shù)及使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-04-04
手把手教你實(shí)現(xiàn)一個(gè)JavaScript時(shí)間軸組件
本文主要是給大家?guī)硪粋€(gè)時(shí)間軸的組件開發(fā)教程,其主要功能就是可以拖動(dòng)時(shí)間軸來定位當(dāng)前時(shí)間,可以通過鼠標(biāo)滾輪來修改當(dāng)前時(shí)間分辨率,需要的可以參考一下2022-10-10
用js腳本控制asp.net下treeview的NodeCheck的實(shí)現(xiàn)代碼
根據(jù)TreeView2.js修改后的TreeView父節(jié)點(diǎn)與子節(jié)點(diǎn)的CheckBox聯(lián)動(dòng).2010-03-03
js項(xiàng)目中添加ts支持實(shí)現(xiàn)示例詳解
這篇文章主要為大家介紹了如何在js項(xiàng)目中添加ts支持實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
javascript通過class來獲取元素實(shí)現(xiàn)代碼
javascript獲取元素有很多的方法,本文簡單的介紹下通過class獲取元素的實(shí)現(xiàn)代碼,感興趣的朋友可以參考下,希望本文知識點(diǎn)可以幫助到你2013-02-02
get(0).tagName獲得作用標(biāo)簽示例代碼
get(0).tagName可獲得作用標(biāo)簽,下面是它的一個(gè)小應(yīng)用,在學(xué)習(xí)js的朋友可以參考下2014-10-10
Javascript判斷文件是否存在(客戶端/服務(wù)器端)
這篇文章主要介紹了Javascript判斷文件是否存在的方法適用于客戶端、服務(wù)器端,遠(yuǎn)程文件,示例代碼如下,需要的朋友可以參考下2014-09-09

