首頁(yè)技術(shù)文章正文

DOM獲取元素的方法有哪些?

更新時(shí)間:2021-06-17 來(lái)源:黑馬程序員 瀏覽量:

IT培訓(xùn)班

在開(kāi)發(fā)中,想要操作頁(yè)面上的某個(gè)部分(如控制一個(gè)div元素的顯示或隱藏、修改div元素的內(nèi)容等),需要先獲取到該部分對(duì)應(yīng)的元素,再對(duì)其進(jìn)行操作。下面我們將分別介紹獲取元素的幾種常見(jiàn)方式。

1.根據(jù)id獲取元素

getElementById0方法是由document對(duì)象提供的用于查找元素的方法。該方法返回的是擁有指定id的元素,如果沒(méi)有找到指定id的元素則返回null, 如果存在多個(gè)指定id的元素則返回undefined。需要注意的是,JavaScript中嚴(yán)格區(qū)分大小寫(xiě),所以在書(shū)寫(xiě)時(shí)一定要遵守書(shū)寫(xiě)規(guī)范,否則程序會(huì)報(bào)錯(cuò)。 下面我們通過(guò)代碼演示document.getElementById('id')方法的使用,示例代碼如下。

<body>
    <div id="box">你好</div>
    <script>
        var Obox = document.getElementById('box');
        console.log(Obox);          //結(jié)果為: <div id="box">你好</div>
        console.log(typeof Obox);   //結(jié)果為: object
        console.dir(Obox);          //結(jié)果為: div#box
    </script>
</body>

在第2行定義了一個(gè)<div>標(biāo)簽,由于文檔是從上往下加載的,所以第3~8行的<script>標(biāo)簽和JavaScript代碼要寫(xiě)在第2行代碼的下面,這樣才可以正確獲取到div元素。第4行代碼用于獲取HTML中id為box的元素,并賦值給變量Obox。需要注意的是,id值不能像CSS那樣加“#”, 如getElementById("#box")是錯(cuò)誤的。第7行的console.dir()方法用來(lái)在控制臺(tái)中查看對(duì)象的屬性和方法。

2.根據(jù)標(biāo)簽獲取元素

根據(jù)標(biāo)簽名獲取元素有兩種方式,分別是通過(guò)document對(duì)象獲取元素和通過(guò)element對(duì)象獲取元素,如下所示。

document.getElementsByTagName('標(biāo)簽名');
element.getElementsByTagName('標(biāo)簽名');

上述代碼中的element是元素對(duì)象的統(tǒng)稱。通過(guò)元素對(duì)象可以查找該元素的子元素或后代元素,實(shí)現(xiàn)局部查找元素的效果,而document對(duì)象是從整個(gè)文檔中查找元素。 由于相同標(biāo)簽名的元素可能有多個(gè),上述方法返回的不是單個(gè)元素對(duì)象,而是一個(gè)集合。這個(gè)集合是一個(gè)類(lèi)數(shù)組對(duì)象,或稱為偽數(shù)組,它可以像數(shù)組一樣用索引來(lái)訪問(wèn)元素,但不能使用push()等方法。使用Array.isArray()也可以證明它不是一個(gè)數(shù)組。下面我們通過(guò)具體代碼進(jìn)行演示。

<body>
    <ul>
        <li>蘋(píng)果</li><li>香蕉</li><li>西瓜</li><li>櫻桃</li>
    </ul>
<ol id="ol">
    <li>綠色</li><li>藍(lán)色</li><li>白色</li><li>紅色</li>
</ol>
<script>
    var lis = document.getElementsByTagName('li');  
    // 結(jié)果為: HTMLCollection(8) [li, li, li, li, li, li, li, li]   
    console.log(lis);
    // 查看集合中的索引為0的元素,結(jié)果為: <li>蘋(píng)果</li>               
    console.log(lis[0]);
    //遍歷集合中的所有元素
    for (var i = 0; i < lis.length; i++) {
        console.log(lis[i]);
    }
    // 通過(guò)元素對(duì)象獲取元素
    var ol = document.getElementById('ol');
    //結(jié)果為: HTMLCollection(4) [li, li, li, li]
    console.log(ol.getElementsByTagNamel('li'));
</script>
</body>

上述代碼中,第2 ~ 4行代碼定義了一個(gè)<ul>無(wú)序列表,第5 ~ 7行代碼定義了一個(gè)id為ol的<ol>有序列表。第9 ~ 17 行代碼演示了document.getElementsByTagName()的用法,其中第9行代碼返回的是所有<li>標(biāo)簽元素對(duì)象的集合。需要注意的是,即使頁(yè)面中只有一個(gè)li元素,返回結(jié)果仍然是一個(gè)集合,如果頁(yè)面中沒(méi)有該元素,那么將會(huì)返回一個(gè)空的集合。 通過(guò)第11行代碼的輸出結(jié)果可以看出,lis是一個(gè)包含8個(gè)li元素的集合對(duì)象,這個(gè)對(duì)象的構(gòu)造函數(shù)是HTMLolletiono第13行代碼返回了集合中的第1個(gè)上元素。第15~ 17行代碼采用遍歷的方式依次打印了集合里面的元素對(duì)象。 第18 ~ 21行代碼演示了element. gelElementsByTagName()的用法,這里的element必須是單個(gè)元素對(duì)象,不能是一- 個(gè)集合,所以需要用document.getElementById0獲取元素,再調(diào)用方法。第21行代碼使用getElementsByTagName()去獲取ol中的所有l(wèi)i元素。

3.根據(jù)name獲取元素

通過(guò)name屬性來(lái)獲取元素應(yīng)使用document.getElementsByName()方法,一般用于獲取表單元素。name屬性的值不要求必須是唯一的,多個(gè)元素也可以有同樣的名字,如表單中的單選框和復(fù)選框。下面我們以復(fù)選框?yàn)槔M(jìn)行代碼演示。

<body>
    <p>請(qǐng)選擇你最喜歡的水果(多選)</p>
    <label><input type="checkbox" name="fruit" value="蘋(píng)果">蘋(píng)果</label>
    <label><input type="checkbox" name="fruit" value="香蕉">香蕉</label>
    <label><input type="checkbox" name="fruit" value="西瓜">西瓜</label>
    <script>
        var fruits = document.getElementsByName('fruit');
        fruits[0].checked = true;
    </script>
</body>

在上述代碼中,getElementsByName()方法返回的是一個(gè)對(duì)象集合,使用索引獲取元素。fruits[0].checked為true,表示將fruits中的第1個(gè)元素的checked屬性值設(shè)置為true,表示將這一項(xiàng)勾選。瀏覽器的預(yù)覽效果如下圖所示。

1623924099395_name獲取元素.png

HTML.5新增的獲取方式

HTML5中為document對(duì)象新增了gelElentsByClassName()、 querySelector()和querSelectorAlI()方法,在使用時(shí)需要考慮到瀏覽器的兼容性問(wèn)題。接下來(lái)我們就來(lái)講解這3種方法的具體使用情況。

1.根據(jù)類(lèi)名獲取

document.getElementsByClassName()方法,用于通過(guò)類(lèi)名來(lái)獲得某些元素集合。下面通過(guò)案例代碼進(jìn)行演示。

<body>
    <span class="one"> 英語(yǔ)</span> <span class="two">數(shù)學(xué)</span>
    <span class="one">語(yǔ)文</span> <span class="two"> 物理</span>
    <script>
        var Ospanl = document.getElementsByClassName('one');
        var Ospan2 = document.getElementsByClassName('two');
        Ospanl[0].style.fontWeight = 'bold';
        Ospan2[1].style.background = 'red';
    </script>
</body>

分別使用getElementsByClassName()方法獲取類(lèi)名為one和two的集合,并分別存儲(chǔ)在Ospan1和Ospan2中。使用下標(biāo)的形式,查找并設(shè)置Ospan1數(shù)組中下標(biāo)為0所對(duì)應(yīng)的第1個(gè)元素的fontWeight屬性為bold,Ospan2 數(shù)組中下標(biāo)為1所對(duì)應(yīng)的第2個(gè)元素的background屬性為red。瀏覽器預(yù)覽效果如下圖所示。

1623924109574_根據(jù)類(lèi)名獲取.png

2.querySelector()和querySelectorAlI()

querySelector()方法用于返回指定選擇器的第一個(gè)元素對(duì)象。querySelecorAlI()方法用于返回指定選擇器的所有元素對(duì)象集合。下面通過(guò)案例代碼進(jìn)行演示。

<body>
    <div class="box">盒子1</div>
    <div class="box">盒子2</div>
    <div id="nav">
        <ul>
            <li>首頁(yè)</li>
            <li>產(chǎn)品</li>
        </ul>
    </div>
    <script>
        var firstBox = document.querySelector('.box');
        console.log(firstBox);  // 獲取class為box的第1個(gè)div
        var nav = document.querySelector('#nav');
        console.log(nav);       // 獲取id為nav的第1個(gè)div
        var li = document.querySelector('li');
        console.log(li);        // 獲取匹配到的第1個(gè)li
        var allBox = document.querySelectorAll('.box');
        console.log(allBox);    //獲取class為box的所有div
        var lis = document.querySelectorAll('li');
        console.log(lis);      //獲取匹配到的所有l(wèi)i
    </script>
</body>

從上述代碼可以看出,在利用querySelector0和querySelectorAl0方法獲取操作的無(wú)系時(shí),直接書(shū)寫(xiě)標(biāo)簽名或CSS選擇器名稱即可。根據(jù)類(lèi)名獲取元素時(shí)在類(lèi)名前面加上“.”,根據(jù)id獲取元素時(shí)在id前面加上“#”。 最后的輸出結(jié)果如下圖所示。

1623912364399_通過(guò)CSS選擇器獲取元素.png



猜你喜歡:

什么是DOM?DOM樹(shù)關(guān)鍵名詞解釋

DOM有多少事件級(jí)別?DOM事件級(jí)別

BOM有幾部分組成?BOM與DOM的區(qū)別是什么?

黑馬程序員HTML&JS+前端培訓(xùn)課程

分享到:
在線咨詢 我要報(bào)名
和我們?cè)诰€交談!