DOM操作

dom對(duì)象的innerText和innerHTML有什么區(qū)別?

  • innerHTML:在讀模式下,innerHTML返回調(diào)用元素的所有子節(jié)點(diǎn)(包括元素娇昙、注釋和文本節(jié)點(diǎn))對(duì)應(yīng)的HTML標(biāo)記轩猩。在寫(xiě)模式下肿轨,innerHTML會(huì)根據(jù)指定的值創(chuàng)建新的DOM樹(shù)上炎,然后用這個(gè)DOM樹(shù)完全替換調(diào)用元素原先的所有子節(jié)點(diǎn)恃逻。
  • innerText:再通過(guò)innerText讀取值時(shí)雏搂,它會(huì)按照由淺入深的順序藕施,將子文檔樹(shù)中的所有文本拼接起來(lái)。在通過(guò)innerText寫(xiě)入值時(shí)凸郑,結(jié)果會(huì)刪除元素的所有子節(jié)點(diǎn)裳食,插入包含相應(yīng)文本值的節(jié)點(diǎn)。在設(shè)置該屬性的同時(shí)芙沥,也對(duì)文本中存在的HTML語(yǔ)法字符(<>&引號(hào))進(jìn)行了編碼(與操作文本節(jié)點(diǎn)nodeValue屬性類(lèi)似)诲祸。

elem.children和elem.childNodes的區(qū)別?

  • childNodes 該屬性保存著一個(gè)NodeList對(duì)象而昨,這是一個(gè)類(lèi)數(shù)組對(duì)象救氯,獨(dú)特之處在于能夠基于DOM結(jié)構(gòu)動(dòng)態(tài)執(zhí)行查詢(xún)結(jié)果,因此DOM結(jié)構(gòu)的變化能夠隨時(shí)反應(yīng)出來(lái)歌憨。
  • children 只包含元素類(lèi)型(nodeType) 為1(Node.ELEMENT_NODE)的子節(jié)點(diǎn)着憨,而childNodes包含所有類(lèi)型的子節(jié)點(diǎn),除此之外沒(méi)有什么區(qū)別务嫡。
  • 對(duì)arguments對(duì)象使用Array.prototype.slice()方法可以將其轉(zhuǎn)化為數(shù)組甲抖。同樣的方法也可以將NodeList對(duì)象轉(zhuǎn)化為數(shù)組。(IE8+)
    var arrayOfNodes = Array.prototype.slice.call(someNode.childNodes,0);

查詢(xún)?cè)赜袔追N常見(jiàn)的方法心铃?ES5的元素選擇方法是什么?

  1. getElementById() 通過(guò)id查詢(xún)?cè)?/li>
  2. getElementsByClassName() 通過(guò)類(lèi)名查詢(xún)?cè)?/li>
  3. getElementsByTagName() 通過(guò)標(biāo)簽名查詢(xún)?cè)?/li>
  4. getElementsByName() 通過(guò)name屬性查詢(xún)?cè)?/li>
  5. ES5的方法:querySelector()/querySelectorAll() 通過(guò)類(lèi)似css選擇器的寫(xiě)法查詢(xún)?cè)刈佳琛6涞讓訉?shí)現(xiàn)類(lèi)似于一組元素的快照,而非不斷對(duì)文檔進(jìn)行搜索的動(dòng)態(tài)查詢(xún)去扣。這樣實(shí)現(xiàn)可以避免使用NodeList對(duì)象通常會(huì)引起的大多數(shù)性能問(wèn)題柱衔。

如何創(chuàng)建一個(gè)元素?如何給元素設(shè)置屬性?如何刪除屬性

  • 創(chuàng)建元素: document.createElement()
  • 設(shè)置屬性: setAttribute('屬性名', '內(nèi)容')唆铐。有因?yàn)樗刑匦远际菍傩源仿耄砸部梢灾苯咏o屬性賦值來(lái)設(shè)置element.className = 'mamba'
  • 刪除屬性:removeAttribute()

如何給頁(yè)面元素添加子元素?如何刪除頁(yè)面元素下的子元素?

這些方法都由其父元素調(diào)用

  • 添加子元素:
    appendChild()把要插入的這個(gè)節(jié)點(diǎn)引用作為返回值返回
    insetBefore(newNode, oneNode)把要插入的這個(gè)節(jié)點(diǎn)引用作為返回值返回或链,即newNode
  • 刪除子元素: removeChild() 返回被刪除的節(jié)點(diǎn)
  • 替換子元素: replaceChild(newNode, oneNode)返回被替換掉的節(jié)點(diǎn)

element.classList有哪些方法惫恼?如何判斷一個(gè)元素的 class 列表中是包含某個(gè) class?如何添加一個(gè)class澳盐?如何刪除一個(gè)class?

  • Element.classList 是一個(gè)只讀屬性祈纯,返回一個(gè)元素的類(lèi)屬性的實(shí)時(shí) DOMTokenList集合。擁有length屬性
  • add( String [, String] )
    添加指定的類(lèi)值叼耙。如果這些類(lèi)已經(jīng)存在于元素的屬性中腕窥,那么它們將被忽略。
  • remove( String [,String] )
    刪除指定的類(lèi)值筛婉。
  • toggle ( String [, force] )
    當(dāng)只有一個(gè)參數(shù)時(shí): 如果類(lèi)存在簇爆,則刪除它并返回false,如果不存在入蛆,則添加它并返回true。
    當(dāng)存在第二個(gè)參數(shù)時(shí):如果第二個(gè)參數(shù)的計(jì)算結(jié)果為true硕勿,則添加指定的類(lèi)值哨毁,如果計(jì)算結(jié)果為false,則刪除它
  • contains( String )
    檢查元素的類(lèi)屬性中是否存在指定的類(lèi)值闹究。

如何選中如下代碼所有的li元素幔崖? 如何選中btn元素蹋订?

<div class="mod-tabs">
   <ul>
       <li>list1</li>
       <li>list2</li>
       <li>list3</li>
   </ul>
   <button class="btn">點(diǎn)我</button>
</div>

所有的li元素:
1.var items = document.getElementsByTagName('li');
2.var items = document.querySelectorAll('.mod-tabs li');
選中btn元素:
1.var items = document.getElementsByClassName('btn');
2.var items = document.querySelector('.btn')

1
1
1
1
11
1
1
1
1
1

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市愧怜,隨后出現(xiàn)的幾起案子丸氛,更是在濱河造成了極大的恐慌梨撞,老刑警劉巖旦签,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件望忆,死亡現(xiàn)場(chǎng)離奇詭異歉备,居然都是意外死亡蕾羊,警方通過(guò)查閱死者的電腦和手機(jī)落午,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)肚豺,“玉大人溃斋,你說(shuō)我怎么就攤上這事∥辏” “怎么了梗劫?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)截碴。 經(jīng)常有香客問(wèn)我梳侨,道長(zhǎng),這世上最難降的妖魔是什么日丹? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任走哺,我火速辦了婚禮,結(jié)果婚禮上哲虾,老公的妹妹穿的比我還像新娘丙躏。我一直安慰自己,他們只是感情好束凑,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布晒旅。 她就那樣靜靜地躺著,像睡著了一般汪诉。 火紅的嫁衣襯著肌膚如雪废恋。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,573評(píng)論 1 305
  • 那天扒寄,我揣著相機(jī)與錄音鱼鼓,去河邊找鬼。 笑死该编,一個(gè)胖子當(dāng)著我的面吹牛迄本,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播上渴,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼岸梨,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼喜颁!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起曹阔,我...
    開(kāi)封第一講書(shū)人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤半开,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后赃份,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體寂拆,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年抓韩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了纠永。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡谒拴,死狀恐怖尝江,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情英上,我是刑警寧澤炭序,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站苍日,受9級(jí)特大地震影響惭聂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜相恃,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一辜纲、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧拦耐,春花似錦耕腾、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至火脉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間柒啤,已是汗流浹背倦挂。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留担巩,地道東北人方援。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像涛癌,于是被迫代替她去往敵國(guó)和親犯戏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子送火,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 基本介紹 文檔對(duì)象模型 (DOM) 是HTML和XML文檔的編程接口。它給文檔(結(jié)構(gòu)樹(shù))提供了一個(gè)結(jié)構(gòu)化的表述并且...
    草鞋弟閱讀 438評(píng)論 0 0
  • 題目1: dom對(duì)象的innerText和innerHTML有什么區(qū)別先匪? innerText是一個(gè)可寫(xiě)屬性种吸,返回元...
    QQQQQCY閱讀 185評(píng)論 0 0
  • 1. dom對(duì)象的innerText和innerHTML有什么區(qū)別? innerText是一個(gè)可寫(xiě)屬性呀非,返回元素內(nèi)...
    _李祺閱讀 278評(píng)論 0 0
  • 1.dom對(duì)象的innerText和innerHTML有什么區(qū)別坚俗? innerText:innerText是一個(gè)可...
    饑人谷_有點(diǎn)熱閱讀 844評(píng)論 0 0
  • 我是從事兒童教育工作的,每天接觸大量?jī)和缍吹浆F(xiàn)在一些孩子的性格體現(xiàn)判呕,我為他們將來(lái)的成長(zhǎng)感到擔(dān)憂(yōu),也深深覺(jué)得家庭教...
    晏姝閱讀 445評(píng)論 0 2