摘要:類型除了該死的其他所有瀏覽器都可以訪問到類型而中所有節(jié)點(diǎn)類型都繼承自類型因此所有節(jié)點(diǎn)類型都共享著相同的基本屬性和方法每個(gè)節(jié)點(diǎn)都有一個(gè)屬性可以表明節(jié)點(diǎn)的類型我們來看看有哪些類型吧和屬性則完全取決于對于元素節(jié)點(diǎn)保存的始終為標(biāo)簽名而保存的值始終為
Node類型
除了IE(該死的IE),其他所有瀏覽器都可以訪問到Node類型,而JS中所有節(jié)點(diǎn)類型都繼承自Node類型,因此所有節(jié)點(diǎn)類型都共享著相同的基本屬性和方法.
每個(gè)節(jié)點(diǎn)都有一個(gè)nodeType屬性,可以表明節(jié)點(diǎn)的類型,我們來看看有哪些類型吧
Node.ELEMENT_NODE(1)
Node.ATTRIBUTE_NODE(2)
Node.TEXT_NODE(3)
Node.CDATA_SECTION_NODE(4)
Node.ENTITY_REFERENCE_NODE(5)
Node.ENTITY_NODE(6)
Node.PROCESSING_INSTRUCTION_NODE(7)
Node.COMMENT_NODE(8)
Node.DOCUMENT_NODE(9)
Node.DOCUMENT_TYPE_NODE(10)
Node.DOCUMENT_FRAGMENT_NODE(11)
Node.NOTATION_NODE(12)
nodeName和nodeValue屬性則完全取決于nodeType,對于元素節(jié)點(diǎn),nodeName保存的始終為標(biāo)簽名,而nodeValue保存的值始終為null
childNodes屬性中保存著一個(gè)NodeList對象(類數(shù)組對象,并不是Array的實(shí)例),NodeList是動態(tài)的,是基于DOM結(jié)構(gòu)動態(tài)執(zhí)行查詢的結(jié)果,我們能通過以下方式來訪問子節(jié)點(diǎn).
var firstChild = someNode.childNodes[0]; var secondChild = someNode.childNodes.item(1); var count = someNode.childNodes.length;
對于NodeList對象,我們還可以轉(zhuǎn)換為數(shù)組,如下
var arrayOfNodes = Array.prototype.slice.call(someNode.childNodes,0);
值得注意,該段代碼在IE8及更早版本前是報(bào)錯(cuò)的,這是因?yàn)镮E8及更早版本將NodeList實(shí)現(xiàn)為一個(gè)COM對象,而我們不能像使用JScript對象那樣使用該對象,所以上述代碼會導(dǎo)致錯(cuò)誤.以下是對于兼容性的解決方法.
function convertToArray(nodes){ var array = null; try{ array = Array.prototype.slice.call(nodes,0);//非IE }catch(ex){ array = new Array(); for(var i = 0,len = nodes.length;i < len;i++){ array.push(node[i]); } } return array; }
每個(gè)節(jié)點(diǎn)還有parentNode屬性,該屬性指向文檔樹中的父節(jié)點(diǎn).包含在childNodes列表中的所有節(jié)點(diǎn)都有相同的父節(jié)點(diǎn),而childNodes列表中的每個(gè)節(jié)點(diǎn)之間為同胞節(jié)點(diǎn),可以通過previousSibling和nextSibling屬性訪問.如果列表只有一個(gè)節(jié)點(diǎn),則該節(jié)點(diǎn)上述兩個(gè)屬性為null.
父節(jié)點(diǎn)與其第一個(gè)和最后一個(gè)子節(jié)點(diǎn)之間也存在特殊關(guān)系.父節(jié)點(diǎn)存在屬性firstChild和lastChild分別指向它們.其中firstChild與childNodes[0]相等,而x.lastChild與x.childNodes[x.childNodes.length-1]相等.
節(jié)點(diǎn)中hasChildNodes()方法也是一個(gè)有用的方法,在包含節(jié)點(diǎn)情況下返回true,否則返回false.
所有節(jié)點(diǎn)最后一個(gè)屬性都為ownerDocument,它指向表示整個(gè)文檔的文檔節(jié)點(diǎn),即#document,可以使我們直接到達(dá)頂層.
操作節(jié)點(diǎn)注意:關(guān)系指針都是只讀的,所以DOM提供了一些函數(shù)供我們操作節(jié)點(diǎn).
以下介紹了四種操作方法,都需要先取得父節(jié)點(diǎn),但是需要明白不是所有類型的節(jié)點(diǎn)都有/支持子節(jié)點(diǎn).
appendChild(node) //向childNodes列表末尾添加一個(gè)節(jié)點(diǎn),并在添加后,關(guān)系指針會相應(yīng)更新.
值得注意的是appendChild()添加的節(jié)點(diǎn)如果已經(jīng)是文檔的一部分,那么相當(dāng)于轉(zhuǎn)移節(jié)點(diǎn).
insertBefore(node,null) //參數(shù)一為插入節(jié)點(diǎn),第二個(gè)參數(shù)則為參照節(jié)點(diǎn),設(shè)為null則效果與appendChild一樣,存在參照節(jié)點(diǎn)則插入節(jié)點(diǎn)變成參照節(jié)點(diǎn)前一個(gè)同胞節(jié)點(diǎn)(previousSibling)移除/替換節(jié)點(diǎn)
removeChild(oldNode) //移除并非替換節(jié)點(diǎn),返回值為oldNode replaceChild(newNode,oldNode) //oldNode替換為newNode,oldNode雖然技術(shù)上仍然存在,但是文檔中沒有了它的位置其他方法
這里有兩個(gè)方法是所有類型節(jié)點(diǎn)都有的,它們就是cloneNode(boolean)和normalize(),我們重點(diǎn)介紹cloneNode()
cloneNode(boolean) //傳入一個(gè)布爾值,該值決定執(zhí)行深復(fù)制(節(jié)點(diǎn)及整個(gè)節(jié)點(diǎn)樹)還是淺復(fù)制(僅復(fù)制本身)
注意點(diǎn)一:深復(fù)制IE9之前版本不會為空白符創(chuàng)建節(jié)點(diǎn),所以深復(fù)制時(shí)childNodes長度會有所不同.
注意點(diǎn)二:cloneNode()方法只復(fù)制特性和子節(jié)點(diǎn)(指定情況下),不會復(fù)制JS屬性如事件處理程序等等(除開IE,存在復(fù)制事件處理程序的bug),所以復(fù)制前最好先移除事件處理程序.
除了Document類型,我們Web編程中最常用的類型就是Element類型啦.
Element 類型用于表現(xiàn)XML或HTML元素,提供了對元素標(biāo)簽名,子節(jié)點(diǎn),特性的訪問
nodeType值為1
nodeName為元素標(biāo)簽名
nodeValue為null
parentNode可能是Document或Element
子節(jié)點(diǎn)可能是Element,Text,Comment,ProcessingInstruction,CDATASection,EntityReference
其中nodeName和tagName屬性返回相同的值,推薦使用tagName,則表義更清晰,值得注意的是返回值大小寫的問題,由于HTML中為答謝,而XML/XHTML則會與源代碼保持一致,所以比較時(shí)要統(tǒng)一大小寫形式.
HTML元素都由HTMLElement類型表示,不直接通過該類型,也是通過它的子類型表示.HTMLElement類型繼承自Element并且添加了一些屬性如下:
id 元素在文檔中的唯一標(biāo)識符
title 元素的附加說明信息,一般為工具提示條顯示
lang 元素內(nèi)容的語言代碼,很少使用
dir 語言方向,ltr為從左到右,rtl則相反
className 與元素class的特性對應(yīng),沒有設(shè)置為class則是因?yàn)閏lass為ECMAScript的保留字
注意以上屬性的修改并不是所有都會在頁面中直觀的表現(xiàn)出來,id和lang修改對用戶來說是不可見的(假設(shè)沒有css樣式),對title的修改則只會在鼠標(biāo)移動到元素上時(shí)才會顯示出來(工具提示條),dir的修改則會在屬性重寫的那一刻立刻影響頁面中的文本,對className的修改則與是否關(guān)聯(lián)了不同的CSS樣式有關(guān).
特性HTML元素每個(gè)元素都有一個(gè)或多個(gè)特性,操作特性的DOM方法如下有三個(gè):
getAttribute()
setAttribute()
removeAttribute()
這三個(gè)方法可以針對任何特性使用,包括自定義特性.
但是只有公認(rèn)的特性才會添加到DOM元素屬性上,自定義的特性通常是不存在的(undefined),當(dāng)然這里又要注意我們的"好朋友"IE啦,它會為自定義特性創(chuàng)建屬性.
特殊特性主要針對getAttribute()方法講述一下特殊情況.
有兩類特殊特性,有對應(yīng)的屬性名,但值與getAttribute()返回的值并不相同
style,通過getAttribute()訪問會返回CSS文本,而通過屬性訪問返回一個(gè)對象
onclick這樣的事件處理程序,通過getAttribute()訪問會返回相應(yīng)代碼的字符串.而屬性訪問時(shí),則會返回一個(gè)JavaScript函數(shù)(未指定則為null)
故通常只有取得自定義特性值的情況下,才會使用getAttribute()方法.
注意!:我們的"老朋友"IE7及以前版本中,getAttribute()方法訪問上述兩個(gè)特殊特性時(shí),返回的值與屬性的值相同.即getAttribute("style")返回一個(gè)對象,getAttribute("onclick")返回一個(gè)函數(shù).
設(shè)置特性這里主要講解下setAttribute()方法,這和getAttribute()相對應(yīng).這個(gè)方法接受兩個(gè)參數(shù),要設(shè)置的特性名和值,如果特性存在則將值進(jìn)行替換;不存在則創(chuàng)建并設(shè)置相應(yīng)的值.
值得注意的是,設(shè)置特性名會轉(zhuǎn)換為小寫.而且直接給DOM元素添加一個(gè)自定義的屬性并不會讓這個(gè)屬性成為元素的特性.
div.mycolor="red"; div.getAttribute("mycolor"); //這里返回null(IE除外)移除特性
removeAttribute()方法用于徹底刪除元素特性,調(diào)用該方法會清除特性的值并完全刪除特性.
注意!:IE6及以前版本不支持該方法.
Element類型是使用attributes屬性的唯一一個(gè)DOM節(jié)點(diǎn)類型.在該屬性中包含一個(gè)NamedNodeMap,與NodeList類似,也是"動態(tài)"集合.元素每一個(gè)特性都由一個(gè)Attr節(jié)點(diǎn)表示,每個(gè)節(jié)點(diǎn)都保存在NamedNodeMap對象中.相關(guān)方法如下:
getNamedItem(name)返回nodeName屬性等于name的節(jié)點(diǎn)
removeNamedItem(name)從列表移除nodeName等于name的節(jié)點(diǎn)
setNamedItem(node)向列表添加節(jié)點(diǎn),以節(jié)點(diǎn)的nodeName屬性為索引
item(pos)返回處于數(shù)字pos位置處的節(jié)點(diǎn)
在該屬性中有一系列的節(jié)點(diǎn),每個(gè)節(jié)點(diǎn)的nodeName就是特性的名稱,nodeValue就是特性的值.要取得元素的id特性,可以使用attributes.getNamedItem("id").nodeValue
等同于attributes["id"].nodeValue
調(diào)用removeNamedItem()與在元素上調(diào)用removeAttribute()效果相同.
setNamedItem()是一個(gè)很不常用的方法,該方法可以為元素添加一個(gè)新特性,此外需要為它傳入一個(gè)特性節(jié)點(diǎn).
注意!:IE7及更早版本會返回HTML元素中所有可能的特性,包括沒指定的特性.
針對低版本改進(jìn):每個(gè)特性節(jié)點(diǎn)都有一個(gè)名為specified的屬性,如果為true則意味著要么HTML中指定了相應(yīng)特性,要么通過setAttribute()設(shè)置了該特性,在IE中未設(shè)置過的特性都為false,其他瀏覽器則不會為這類特性生成對應(yīng)特性節(jié)點(diǎn).
document.createElement()方法就可創(chuàng)建新元素.
該方法接受一個(gè)參數(shù),就是元素標(biāo)簽名,這個(gè)標(biāo)簽名在HTML下不區(qū)分大小寫,XML中則會區(qū)分大小寫.
在創(chuàng)建新元素的同時(shí),新元素也設(shè)置了ownerDocument屬性,此時(shí),還可以操作元素特性,為它添加更多的子節(jié)點(diǎn).
在設(shè)置完特性后,由于未添加到文檔樹,所以一切特性都不會影響瀏覽器的顯示.我們可以通過之前講到的appendChild(),insertBefore(),replaceChild()方法來進(jìn)行相應(yīng)的操作.
一旦添加到文檔樹,則瀏覽器會立刻呈現(xiàn)該元素.此后我們的修改都會反應(yīng)到瀏覽器中.
注意!(常不考慮):在IE中我們可以通過另一種方式進(jìn)行創(chuàng)建
document.createElement("");
這個(gè)方式可以避開IE7及更早版本中動態(tài)創(chuàng)建元素的某些問題.(不能設(shè)置動態(tài)創(chuàng)建的iframe元素的name特性;不能通過表單的reset()方法重設(shè)動態(tài)創(chuàng)建的input元素;動態(tài)創(chuàng)建的type特性值為"reset"的button元素重設(shè)不了表單;動態(tài)創(chuàng)建的一批name相同的單選按鈕彼此毫無關(guān)系)
元素子節(jié)點(diǎn)
除了IE,其他瀏覽器解析代碼時(shí)會解析空白符為文本節(jié)點(diǎn).我們可以通過nodeType屬性的檢查來過濾掉它們.
在JavaScript中Document類型表示文檔,我們常用的document對象是HTMLDocument(繼承自Document類型)的一個(gè)實(shí)例,表示整個(gè)HTML頁面;document對象還是window對象的一個(gè)屬性,因此可以將其作為全局對象來訪問.
特征nodeType值為9
nodeName為"#document"
nodeValue為null
parentNode為null
ownerDocument為null
子節(jié)點(diǎn)可能是一個(gè)DocumentType(最多一個(gè)),Element(最多一個(gè)),ProcessingInstruction或Comment
Document類型可以表示HTML頁面或者其他基于XML的文檔,不過最常見的應(yīng)用還是作為HTMLDocument實(shí)例的document對象.通過該對象,我們可以獲取頁面有關(guān)信息,操作頁面的外觀,以及其底層結(jié)構(gòu).
雖然DOM標(biāo)準(zhǔn)規(guī)定Document節(jié)點(diǎn)的子節(jié)點(diǎn)可以是DocumentType,Element,ProcessingInstruction或Comment,但是還有兩個(gè)內(nèi)置的訪問其子節(jié)點(diǎn)的快捷方式.
一:documentElement屬性-始終指向HTML頁面中的元素
二:childNodes列表
并且如下代碼所示
//html部分 // // // var html = document.documentElement; console.log(html === document.childNodes[0]); //true console.log(html === document.firstChild); //true
可見documentElement,firstChild,childNodes[0]指向同一個(gè)元素
并且作為HTMLDocument的實(shí)例,還有一個(gè)body屬性,直接指向元素.
所有瀏覽器都支持document.documentElement和document.body屬性
DocumentType節(jié)點(diǎn)(不重要)節(jié)點(diǎn)可以通過document.doctype屬性獲取并訪問它的信息.
以下是各瀏覽器支持差別:
IE8及之前:存在文檔類型聲明,會錯(cuò)誤解釋為一個(gè)注釋并把它當(dāng)作Comment節(jié)點(diǎn);而document.doctype 值始終為null
IE9+及firefox:如果存在文檔類型聲明,則會將其作為文檔第一個(gè)子節(jié)點(diǎn);document.doctype是一個(gè)DocumentType節(jié)點(diǎn),也可以通過document.firstChild或document.childNodes[0]訪問.
Safari,Chrome和Opera:如果存在文檔類型聲明,則會將其解析,但不作為文檔子節(jié)點(diǎn),document.doctype是一個(gè)DocumentType節(jié)點(diǎn),但該節(jié)點(diǎn)不存在于document.childNodes中.
Comment(不重要)對于上述注釋也在不同瀏覽器中存在不同.
IE8及之前,Safari3.1及更高,Opera和chrome:只為第一條注釋創(chuàng)建節(jié)點(diǎn),部位第二條注釋創(chuàng)建節(jié)點(diǎn).
IE9+:將第一條注釋創(chuàng)建為document.childNodes中的一個(gè)注釋節(jié)點(diǎn),也將第二條注釋創(chuàng)建為document.childNodes中的注釋子節(jié)點(diǎn)
Safari3.1之前,firefox:完全忽略
以上的不一致性導(dǎo)致了無論是注釋還是DocumentType節(jié)點(diǎn)對于我們來說用處十分有限.
文檔信息document對象有屬性提供了document對象所表現(xiàn)的網(wǎng)頁的一些信息.
title:包含在
URL:包含頁面完整的URL
domain:包含頁面的域名
referrer:保存鏈接到當(dāng)前頁面的那個(gè)頁面的URL,如無來源頁面則為空字符串.
注意!:這些信息都存在于HTTP頭部,只不過我們能通過該屬性在JS中訪問它們.而且我們只能在遵守規(guī)則(不能將這個(gè)屬性設(shè)置為URL中不包含的域,不能將域縮緊如將wrox.com設(shè)置為p2p.wrox.com一樣(IE8及之后))的情況下設(shè)置domain屬性.
其中domain屬性還是越過跨域安全限制的好辦法.
查找元素主要用到document對象以下方法.
getElementById("id") //接受一個(gè)參數(shù),如果找到相應(yīng)元素則返回該元素,不存在則返回null //注意!:IE8及較低版本不區(qū)分ID大小寫/如果存在多個(gè)ID則只返回第一次出現(xiàn)的/IE7及較低版本中name值與ID匹配的表單元素會被返回 getElementsByTagName("img") //接受一個(gè)參數(shù),為要取得元素的標(biāo)簽名,返回一個(gè)NodeList(包含零或多個(gè)元素).在HTML文檔中,這個(gè)方法返回一個(gè)HTMLCollection對象,該對象與NodeList非常類似 getElementsByName("name") //只有HTMLDocument類型才有的方法.和上述兩個(gè)方法相似,也就不解釋傳入?yún)?shù)之類的啦HTMLCollection對象
元素?cái)?shù)量可以通過length獲得,而且我們可以通過.item()和方括號語法[0]/["name特性"]來訪問元素.namedItem()方法則可以通過name特性取得其中的元素.
特殊集合除了屬性和方法,document對象還有一些特殊集合.這些集合都是HTMLCollection對象,為訪問文檔常用部分提供了快捷方式,如下:
document.anchors 包含文檔中所有帶name特性的元素
document.applets 包含文檔中所有的元素(已不再推薦使用)
document.forms 包含文檔中所有元素
document.images 包含文檔中所有元素
document.links 包含文檔中所有帶href特性的元素
該集合始終可以通過HTMLDocument對象訪問到.而且是動態(tài)的隨著當(dāng)前文檔內(nèi)容的更新而更新.
document.implementation屬性就是用在檢測瀏覽器實(shí)現(xiàn)了DOM的哪些部分.
document.implementation.hasFeature()方法接受兩個(gè)參數(shù),要檢測的DOM功能名稱和版本號,如果瀏覽器支持則返回true.但是這并不代表著實(shí)現(xiàn)與規(guī)范一致
document對象有一個(gè)存在很久的功能,將輸出流寫入到網(wǎng)頁中的能力.這關(guān)乎到下列4個(gè)方法.
write()
writeln()
上面兩個(gè)方法都是接受一個(gè)字符串參數(shù),writeln()額外在字符串寫入后再寫入一個(gè)換行符
注意!:如果要用于寫入則要對進(jìn)行轉(zhuǎn)義=>,防止script標(biāo)簽被提前閉合導(dǎo)致無法執(zhí)行;如果在文檔接在結(jié)束后再調(diào)用則會導(dǎo)致整個(gè)頁面重寫.
open()
close()
上述兩個(gè)方法用于打開和關(guān)閉網(wǎng)頁的輸出流,如果在頁面加載期間使用write()和writeln()則不需要用到這兩個(gè)方法(嚴(yán)格型的XHTML文檔不支持文檔寫入)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/91034.html
摘要:主要介紹不常用的類型這里介紹我們的其他類型包括以下幾個(gè)類型類型類型類型類型類型類型類型文本節(jié)點(diǎn)由類型表示特征值為為為節(jié)點(diǎn)包含的文本是一個(gè)不支持沒有子節(jié)點(diǎn)我們可以通過訪問節(jié)點(diǎn)包含的文本方法將添加到節(jié)點(diǎn)末尾從指定位置開始刪除個(gè)字符從指定 主要介紹不常用的DOM類型 這里介紹我們的其他類型,包括以下幾個(gè)類型: Text類型 Comment類型 CDATASection類型 Document...
摘要:簡介簡史誕生于年,當(dāng)時(shí)主要負(fù)責(zé)表單的輸入驗(yàn)證。實(shí)現(xiàn)一個(gè)完整的由三部分組成核心文檔對象模型瀏覽器對象模型就是對實(shí)現(xiàn)該標(biāo)準(zhǔn)規(guī)定的各個(gè)方面內(nèi)容的語言的描述。把整個(gè)頁面映射為一個(gè)多層節(jié)點(diǎn)結(jié)構(gòu)。由萬維網(wǎng)聯(lián)盟規(guī)劃。主要目標(biāo)是映射文檔的結(jié)構(gòu)。 JavaScript簡介 JavaScript簡史 JavaScript誕生于1995年,當(dāng)時(shí)主要負(fù)責(zé)表單的輸入驗(yàn)證。 如果沒有表單驗(yàn)證的功能,填入信息之...
摘要:在基于使用命名空間的文檔求值時(shí),需要使用對象。第四個(gè)參數(shù)的取值類型是下列常量之一,返回與表達(dá)式匹配的數(shù)據(jù)類型。,返回字符串值。這是最常用的結(jié)果類型。集合中節(jié)點(diǎn)的次序與它們在文檔中的次序一致。 JavaScript與XML 瀏覽器對XML DOM的支持 DOM2級核心 在通過JavaScript處理XML時(shí),通常只使用參數(shù)root,因?yàn)檫@個(gè)參數(shù)指定的是XML DOM文檔元素的標(biāo)簽名 v...
摘要:為屬性賦值匿名函數(shù)事件作用域使用級方法指定的事件處理程序被認(rèn)為是元素的方法。最后這個(gè)布爾值參數(shù)如果是,表示在捕獲階段調(diào)用事件處理程序如果是,表示在冒泡階段調(diào)用事件處理程序。 事件捕獲和事件冒泡 DOM2級事件規(guī)定的事件流包括三個(gè)階段:事件捕獲、處于目標(biāo)階段和事件冒泡。首先發(fā)生的是事件捕獲,從外部節(jié)點(diǎn)到內(nèi)部節(jié)點(diǎn)依次遍歷,為截獲事件提供了機(jī)會。然后是實(shí)際的目標(biāo)接收到事件。最后一個(gè)階段是冒泡...
摘要:為屬性賦值匿名函數(shù)事件作用域使用級方法指定的事件處理程序被認(rèn)為是元素的方法。最后這個(gè)布爾值參數(shù)如果是,表示在捕獲階段調(diào)用事件處理程序如果是,表示在冒泡階段調(diào)用事件處理程序。 事件捕獲和事件冒泡 DOM2級事件規(guī)定的事件流包括三個(gè)階段:事件捕獲、處于目標(biāo)階段和事件冒泡。首先發(fā)生的是事件捕獲,從外部節(jié)點(diǎn)到內(nèi)部節(jié)點(diǎn)依次遍歷,為截獲事件提供了機(jī)會。然后是實(shí)際的目標(biāo)接收到事件。最后一個(gè)階段是冒泡...
閱讀 3266·2021-11-18 10:02
閱讀 1469·2021-10-12 10:08
閱讀 1271·2021-10-11 10:58
閱讀 1285·2021-10-11 10:57
閱讀 1182·2021-10-08 10:04
閱讀 2138·2021-09-29 09:35
閱讀 787·2021-09-22 15:44
閱讀 1284·2021-09-03 10:30