JS操作中的DOM對象

什么是DOM對象

DOM(Document Object Model)即文檔對象模型,針對HTML和XML文檔的API(應(yīng)用程序接口)染坯。
DOM描繪了一個(gè)層次化的節(jié)點(diǎn)樹均芽,允許開發(fā)人員添加、移除和修改頁面的某一部分单鹿。

提示:Document 對象是 Window 對象的一部分掀宋,可通過 window.document 屬性對其進(jìn)行訪問。

DOM樹.png
  • 整個(gè)文檔是一個(gè)文檔節(jié)點(diǎn)
  • 包含在 HTML 元素中的文本是文本節(jié)點(diǎn)
  • 每一個(gè) HTML 屬性是一個(gè)屬性節(jié)點(diǎn)
  • 注釋屬于注釋節(jié)點(diǎn)

查找元素節(jié)點(diǎn)

1仲锄、通過元素的id查找節(jié)點(diǎn)

語法:var name = document.getElementById(“ID”);
????ID:要獲取的元素ID
????name:聲明要找到的元素劲妙,沒找到,則返回null

    <div id="box">
        獲取id元素
    </div>
    <script>
    var box = document.getElementById("box");    // 獲取id名為box的div
    box.addEventListener("click",function(){     // 點(diǎn)擊事件
        alert("獲取id元素")                      //返回彈出框
    })
    </script>
2儒喊、通過元素的類名查找節(jié)點(diǎn)

語法:var name = document.getElementsByClassName(“classname”);
????classname:要獲取的元素的類名
????name:聲明要找到的元素镣奋,沒找到,則返回undefined

    <div class="box">
        獲取class元素
    </div>
    <script>
    var box = document.getElementsByClassName("box")[0];
    console.log(box)
    box.addEventListener("click",function(){
        alert("獲取class元素")
    })
    </script>

3怀愧、通過標(biāo)簽名查找節(jié)點(diǎn)

語法:document.getElementsByTagname(tagName)
?????elem.getElementsByTagname(tagName)
返回值為由指定標(biāo)簽元素所組成的數(shù)組

    <div class="box">
        <ul>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </div>
    <script>
    var list = document.getElementsByTagName("li");
    console.log(list)     
    </script>

打印結(jié)果如下:


tagName.jpg

4侨颈、通過元素的name值查找節(jié)點(diǎn)(優(yōu)先使用在單選按鈕和復(fù)選框中)

語法:document.getElementsByName(name)
返回值:由指定name值的元素所組成的數(shù)組

<div class="box">
        <input type="checkbox" name="ipts">
        <input type="checkbox" name="ipts">
        <input type="checkbox" name="ipts">
        <input type="checkbox" name="ipts">
        <input type="checkbox" name="ipts">
    </div>
    <script>
    var ipts = document.getElementsByName("ipts");
    console.log(ipts)
    </script>

打印結(jié)果如下:


name.png

5、獲取元素的屬性

語法:name.getAttribute(“attribute”)
name:要操作的dom對象
attribute:要獲取的html屬性

     <div class="box">
       <a href="###"></a>
    </div>
    <script>
    var a = document.getElementsByTagName("a")[0];
    console.log(a.getAttribute("href"))
    </script>

返回值a標(biāo)簽的屬性href內(nèi)的內(nèi)容為 ###

6掸驱、為元素設(shè)置屬性

語法:name.setAttribute(“attribute”,value)
value:設(shè)置屬性的值

    <div class="box">
       <a href="###"></a>
    </div>
    <script>
    var a = document.getElementsByTagName("a")[0];
    a.setAttribute("name","ass")
    console.log(a)
    </script>

返回值如圖:


setA.png

7肛搬、刪除元素的屬性

語法:name.removeAttribute(“attribute”)

    <div class="box">
       <img src="#" alt="#" title="iamremove">
    </div>
    <script>
    var img = document.getElementsByTagName("img")[0];
    img.removeAttribute("title")
    console.log(img)
    </script>

返回值如圖:


remove.png

DOM對象設(shè)置元素的樣式

1、使用setAttribute()設(shè)置class屬性值

語法:elem.setAttribute(“class”,“類選擇器”);

2毕贼、使用元素的 className 屬性修改 class 值

語法:elem.className = “類名”;

3、自定義元素樣式

語法:name.style.css屬性 = "值";

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蛤奢,一起剝皮案震驚了整個(gè)濱河市鬼癣,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌啤贩,老刑警劉巖待秃,帶你破解...
    沈念sama閱讀 216,744評論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異痹屹,居然都是意外死亡章郁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,505評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來暖庄,“玉大人聊替,你說我怎么就攤上這事∨嗬” “怎么了惹悄?”我有些...
    開封第一講書人閱讀 163,105評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長肩钠。 經(jīng)常有香客問我泣港,道長,這世上最難降的妖魔是什么价匠? 我笑而不...
    開封第一講書人閱讀 58,242評論 1 292
  • 正文 為了忘掉前任当纱,我火速辦了婚禮,結(jié)果婚禮上踩窖,老公的妹妹穿的比我還像新娘坡氯。我一直安慰自己,他們只是感情好毙石,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,269評論 6 389
  • 文/花漫 我一把揭開白布廉沮。 她就那樣靜靜地躺著,像睡著了一般徐矩。 火紅的嫁衣襯著肌膚如雪滞时。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,215評論 1 299
  • 那天滤灯,我揣著相機(jī)與錄音坪稽,去河邊找鬼。 笑死鳞骤,一個(gè)胖子當(dāng)著我的面吹牛窒百,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播豫尽,決...
    沈念sama閱讀 40,096評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼篙梢,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了美旧?” 一聲冷哼從身側(cè)響起渤滞,我...
    開封第一講書人閱讀 38,939評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎榴嗅,沒想到半個(gè)月后妄呕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,354評論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡嗽测,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,573評論 2 333
  • 正文 我和宋清朗相戀三年绪励,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,745評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡疏魏,死狀恐怖停做,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情蠢护,我是刑警寧澤雅宾,帶...
    沈念sama閱讀 35,448評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站葵硕,受9級特大地震影響眉抬,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜懈凹,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,048評論 3 327
  • 文/蒙蒙 一蜀变、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧介评,春花似錦库北、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,683評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至坪仇,卻和暖如春杂腰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背椅文。 一陣腳步聲響...
    開封第一講書人閱讀 32,838評論 1 269
  • 我被黑心中介騙來泰國打工喂很, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人皆刺。 一個(gè)月前我還...
    沈念sama閱讀 47,776評論 2 369
  • 正文 我出身青樓少辣,卻偏偏與公主長得像,于是被迫代替她去往敵國和親羡蛾。 傳聞我的和親對象是個(gè)殘疾皇子漓帅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,652評論 2 354

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

  • ??DOM(文檔對象模型)是針對 HTML 和 XML 文檔的一個(gè) API(應(yīng)用程序編程接口)煎殷。 ??DOM 描繪...
    霜天曉閱讀 3,644評論 0 7
  • 概要 64學(xué)時(shí) 3.5學(xué)分 章節(jié)安排 電子商務(wù)網(wǎng)站概況 HTML5+CSS3 JavaScript Node 電子...
    阿啊阿吖丁閱讀 9,182評論 0 3
  • 第一章 1.什么是DOM DOM: Document Object Model(文檔對象模型) 是JavaScri...
    fastwe閱讀 799評論 0 0
  • 前言:盡管現(xiàn)在有很多優(yōu)秀的框架,大大簡化了我們的DOM操作腿箩,但是我們?nèi)匀灰獙W(xué)好DOM知識來寫原生JS,從根本上去理...
    長鯨向南閱讀 1,869評論 0 0
  • ??DOM 1 級主要定義的是 HTML 和 XML 文檔的底層結(jié)構(gòu)。 ??DOM2 和 DOM3 級則在這個(gè)結(jié)構(gòu)...
    霜天曉閱讀 1,440評論 1 3