溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jQuery操作DOM的示例分析

發(fā)布時(shí)間:2021-08-12 09:59:18 來源:億速云 閱讀:123 作者:小新 欄目:web開發(fā)

這篇文章主要介紹jQuery操作DOM的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

jQuery的選擇器很強(qiáng)大,用起來又簡(jiǎn)單又靈活,但是搞了這么久,我拿到了jQuery對(duì)象,到底要干什么?

答案當(dāng)然是操作對(duì)應(yīng)的DOM節(jié)點(diǎn)啦!

回顧一下修改DOM的CSS、文本、設(shè)置HTML有多么麻煩,而且有的瀏覽器只有innerHTML,有的瀏覽器支持innerText,有了jQuery對(duì)象,不需要考慮瀏覽器差異了,全部統(tǒng)一操作!

修改Text和HTML

jQuery對(duì)象的text()html()方法分別獲取節(jié)點(diǎn)的文本和原始HTML文本,例如,如下的HTML結(jié)構(gòu):

<!-- HTML結(jié)構(gòu) -->
<ul id="test-ul">
  <li class="js">JavaScript</li>
  <li name="book">Java &amp; JavaScript</li>
</ul>

分別獲取文本和HTML:

$('#test-ul li[name=book]').text(); // 'Java & JavaScript'
$('#test-ul li[name=book]').html(); // 'Java &amp; JavaScript'

如何設(shè)置文本或HTML?jQuery的API設(shè)計(jì)非常巧妙:無參數(shù)調(diào)用text()是獲取文本,傳入?yún)?shù)就變成設(shè)置文本,HTML也是類似操作,自己動(dòng)手試試:

'use strict';
var j1 = $('#test-ul li.js');
var j2 = $('#test-ul li[name=book]');
j1.html('<span >JavaScript</span>');
j2.text('JavaScript & ECMAScript');

一個(gè)jQuery對(duì)象可以包含0個(gè)或任意個(gè)DOM對(duì)象,它的方法實(shí)際上會(huì)作用在對(duì)應(yīng)的每個(gè)DOM節(jié)點(diǎn)上。在上面的例子中試試:

$('#test-ul li').text('JS'); // 是不是兩個(gè)節(jié)點(diǎn)都變成了JS?

所以jQuery對(duì)象的另一個(gè)好處是我們可以執(zhí)行一個(gè)操作,作用在對(duì)應(yīng)的一組DOM節(jié)點(diǎn)上。即使選擇器沒有返回任何DOM節(jié)點(diǎn),調(diào)用jQuery對(duì)象的方法仍然不會(huì)報(bào)錯(cuò):

// 如果不存在id為not-exist的節(jié)點(diǎn):
$('#not-exist').text('Hello'); // 代碼不報(bào)錯(cuò),沒有節(jié)點(diǎn)被設(shè)置為'Hello'

這意味著jQuery幫你免去了許多if語句。

修改CSS

jQuery對(duì)象有“批量操作”的特點(diǎn),這用于修改CSS實(shí)在是太方便了??紤]下面的HTML結(jié)構(gòu):

<!-- HTML結(jié)構(gòu) -->
<ul id="test-css">
  <li class="lang dy"><span>JavaScript</span></li>
  <li class="lang"><span>Java</span></li>
  <li class="lang dy"><span>Python</span></li>
  <li class="lang"><span>Swift</span></li>
  <li class="lang dy"><span>Scheme</span></li>
</ul>

要高亮顯示動(dòng)態(tài)語言,調(diào)用jQuery對(duì)象的css('name', 'value')方法,我們用一行語句實(shí)現(xiàn):

'use strict';
$('#test-css li.dy>span').css('background-color', '#ffd351').css('color', 'red');

注意,jQuery對(duì)象的所有方法都返回一個(gè)jQuery對(duì)象(可能是新的也可能是自身),這樣我們可以進(jìn)行鏈?zhǔn)秸{(diào)用,非常方便。
jQuery對(duì)象的css()方法可以這么用:

var div = $('#test-div');
div.css('color'); // '#000033', 獲取CSS屬性
div.css('color', '#336699'); // 設(shè)置CSS屬性
div.css('color', ''); // 清除CSS屬性

為了和JavaScript保持一致,CSS屬性可以用'background-color''backgroundColor'兩種格式。

css()方法將作用于DOM節(jié)點(diǎn)的style屬性,具有最高優(yōu)先級(jí)。如果要修改class屬性,可以用jQuery提供的下列方法:

var div = $('#test-div');
div.hasClass('highlight'); // false, class是否包含highlight
div.addClass('highlight'); // 添加highlight這個(gè)class
div.removeClass('highlight'); // 刪除highlight這個(gè)class

顯示和隱藏DOM

要隱藏一個(gè)DOM,我們可以設(shè)置CSS的display屬性為none,利用css()方法就可以實(shí)現(xiàn)。不過,要顯示這個(gè)DOM就需要恢復(fù)原有的display屬性,這就得先記下來原有的display屬性到底是block還是inline還是別的值。

考慮到顯示和隱藏DOM元素使用非常普遍,jQuery直接提供show()hide()方法,我們不用關(guān)心它是如何修改display屬性的,總之它能正常工作:

var a = $('a[target=_blank]');
a.hide(); // 隱藏
a.show(); // 顯示

注意,隱藏DOM節(jié)點(diǎn)并未改變DOM樹的結(jié)構(gòu),它只影響DOM節(jié)點(diǎn)的顯示。這和刪除DOM節(jié)點(diǎn)是不同的。

獲取DOM信息

利用jQuery對(duì)象的若干方法,我們直接可以獲取DOM的高寬等信息,而無需針對(duì)不同瀏覽器編寫特定代碼:

// 瀏覽器可視窗口大小:
$(window).width(); // 800
$(window).height(); // 600

// HTML文檔大小:
$(document).width(); // 800
$(document).height(); // 3500

// 某個(gè)div的大小:
var div = $('#test-div');
div.width(); // 600
div.height(); // 300
div.width(400); // 設(shè)置CSS屬性 width: 400px,是否生效要看CSS是否有效
div.height('200px'); // 設(shè)置CSS屬性 height: 200px,是否生效要看CSS是否有效

attr()removeAttr()方法用于操作DOM節(jié)點(diǎn)的屬性:

// <div id="test-div" name="Test" start="1">...</div>
var div = $('#test-div');
div.attr('data'); // undefined, 屬性不存在
div.attr('name'); // 'Test'
div.attr('name', 'Hello'); // div的name屬性變?yōu)?#39;Hello'
div.removeAttr('name'); // 刪除name屬性
div.attr('name'); // undefined

prop()方法和attr()類似,但是HTML5規(guī)定有一種屬性在DOM節(jié)點(diǎn)中可以沒有值,只有出現(xiàn)與不出現(xiàn)兩種,例如:

<input id="test-radio" type="radio" name="test" checked value="1">

等價(jià)于:

<input id="test-radio" type="radio" name="test" checked="checked" value="1">

attr()prop()對(duì)于屬性checked處理有所不同:

var radio = $('#test-radio');
radio.attr('checked'); // 'checked'
radio.prop('checked'); // true

prop()返回值更合理一些。不過,用is()方法判斷更好:

var radio = $('#test-radio');
radio.is(':checked'); // true

類似的屬性還有selected,處理時(shí)最好用is(':selected')。

操作表單

對(duì)于表單元素,jQuery對(duì)象統(tǒng)一提供val()方法獲取和設(shè)置對(duì)應(yīng)的value屬性:

/*
  <input id="test-input" name="email" value="">
  <select id="test-select" name="city">
    <option value="BJ" selected>Beijing</option>
    <option value="SH">Shanghai</option>
    <option value="SZ">Shenzhen</option>
  </select>
  <textarea id="test-textarea">Hello</textarea>
*/
var
  input = $('#test-input'),
  select = $('#test-select'),
  textarea = $('#test-textarea');

input.val(); // 'test'
input.val('abc@example.com'); // 文本框的內(nèi)容已變?yōu)閍bc@example.com

select.val(); // 'BJ'
select.val('SH'); // 選擇框已變?yōu)镾hanghai

textarea.val(); // 'Hello'
textarea.val('Hi'); // 文本區(qū)域已更新為'Hi'

以上是“jQuery操作DOM的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI