DOM API

課堂筆記

  • DOM(document,object,model)的作用是通過構(gòu)造函數(shù)將網(wǎng)頁文檔里的標簽轉(zhuǎn)化為對象茬暇,這個過程稱為建立模型(Model), DOM樹根節(jié)點為<html>對象糙俗,DOM的最小組成單位是節(jié)點(node)
  • previousSibling()nextSibling()可能獲取到文本節(jié)點,為保證獲取到想要的元素結(jié)點巧骚,必要時加入判斷條件:.nodeType()方法,對應(yīng)返回值:1 為元素節(jié)點 劈彪; 3 為文本節(jié)點(回車屬于文本節(jié)點)
  • innerText() textContent() innerHTML()
  • cloneNode()cloneNode(deep)
  • node1.isEqualNode(node2)node1.isSameNode(node2)

動態(tài)集合與靜態(tài)集合

var parent = document.getElementById('parent');
parent.childNodes.length // 2
parent.appendChild(document.createElement('div'));
parent.childNodes.length // 請問現(xiàn)在 length 是多少? 3

var allDiv = document.querySelectorAll('div')
allDiv.length  // 假設(shè)是 2
document.body.appendChild(  document.createElement('div')  )
allDiv.length // 請問現(xiàn)在 length 的值是多少草添? 2

一部分教程將上面這兩段代碼的區(qū)別解釋為:.querySelectorAll() 返回值是靜態(tài)的偽數(shù)組,而 .childNodes() 返回動態(tài)數(shù)組远寸。這種解釋便于記憶但并不指向?qū)嵸|(zhì)。
代碼段2中驰后,allDiv.querySelector()返回的偽數(shù)組的引用,在被賦值之后灶芝,它的值沒有發(fā)生任何變化。而代碼段1并沒有將parent.chilNodes賦值給任何變量夜涕,每次取它的長度,看起來就好像動態(tài)地實時更新一樣女器。

將代碼段2改成:

var allDiv = document.querySelectorAll('div')
allDiv.length  // 假設(shè)是 2
document.body.appendChild(  document.createElement('div')  )
document.querySelectorAll('div').length // 3

效果就跟代碼段1一樣了

IIFE 與 let 的優(yōu)越性

IIFE即函數(shù)立即調(diào)用的表達式。

為什么要有IIFE涣澡?
因為網(wǎng)頁在生成時已經(jīng)有一大堆全局變量,如果想用與全局變量同名的變量而不想覆蓋全局變量入桂,這時候就需要“函數(shù)立即調(diào)用”。
使用形式:

 !function(){
    函數(shù)體
    return 局部變量
}()

可以看到匿名函數(shù)之后立即跟小括號表示調(diào)用
為什么要加感嘆號抗愁?
若不加感嘆號,這段代碼會被瀏覽器當(dāng)作函數(shù)聲明語句驹愚,直接調(diào)用是不被允許的,加感嘆號是在告訴瀏覽器將這段代碼當(dāng)作表達式來執(zhí)行,同理也可以將谁鳍!換成+,-倘潜,~等符號

既生var何生let?

let在ES6中被引入,同樣用于聲明變量涮因,但只在let所在的局部作用域有效,這與var變量提升的性質(zhì)截然不同养泡,簡便了局部變量的使用奈应。
let同時為js引入了塊級作用域,在此之前js只有函數(shù)作用域和全局作用域购披。
塊級作用域的出現(xiàn),實際上使得獲得廣泛應(yīng)用的立即執(zhí)行函數(shù)表達式(IIFE)不再必要了刚陡。

clientX/Y觸發(fā)點視口距離
pageX/Y觸發(fā)點文檔(網(wǎng)頁)距離
offsetX/Y觸發(fā)點相對于被觸發(fā)的DOM的距離
screenX/Y觸發(fā)點相對于顯示器左上角的距離

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筐乳,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蝙云,更是在濱河造成了極大的恐慌,老刑警劉巖贮懈,帶你破解...
    沈念sama閱讀 218,386評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異朵你,居然都是意外死亡,警方通過查閱死者的電腦和手機抡医,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評論 3 394
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來忌傻,“玉大人,你說我怎么就攤上這事水孩。” “怎么了俘种?”我有些...
    開封第一講書人閱讀 164,704評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長宙刘。 經(jīng)常有香客問我,道長悬包,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,702評論 1 294
  • 正文 為了忘掉前任垫释,我火速辦了婚禮,結(jié)果婚禮上饶号,老公的妹妹穿的比我還像新娘。我一直安慰自己茫船,他們只是感情好琅束,可當(dāng)我...
    茶點故事閱讀 67,716評論 6 392
  • 文/花漫 我一把揭開白布涩禀。 她就那樣靜靜地躺著,像睡著了一般艾船。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上屿岂,一...
    開封第一講書人閱讀 51,573評論 1 305
  • 那天鲸匿,我揣著相機與錄音,去河邊找鬼带欢。 笑死运授,一個胖子當(dāng)著我的面吹牛乔煞,可吹牛的內(nèi)容都是我干的吁朦。 我是一名探鬼主播渡贾,決...
    沈念sama閱讀 40,314評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼空骚!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起府怯,我...
    開封第一講書人閱讀 39,230評論 0 276
  • 序言:老撾萬榮一對情侶失蹤牺丙,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體粟判,經(jīng)...
    沈念sama閱讀 45,680評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡峦剔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,873評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了吝沫。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,991評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡惨险,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出辫愉,到底是詐尸還是另有隱情,我是刑警寧澤恭朗,帶...
    沈念sama閱讀 35,706評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站痰腮,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏诽嘉。R本人自食惡果不足惜蔚出,卻給世界環(huán)境...
    茶點故事閱讀 41,329評論 3 330
  • 文/蒙蒙 一骄酗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧悦冀,春花似錦、人聲如沸盒蟆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,910評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至寒屯,卻和暖如春黍少,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背处面。 一陣腳步聲響...
    開封第一講書人閱讀 33,038評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留魂角,地道東北人。 一個月前我還...
    沈念sama閱讀 48,158評論 3 370
  • 正文 我出身青樓野揪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親囱挑。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,941評論 2 355