溫馨提示×

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

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

jquery中attr、prop、data區(qū)別與用法分析

發(fā)布時(shí)間:2020-08-30 07:00:09 來(lái)源:腳本之家 閱讀:141 作者:學(xué)知無(wú)涯 欄目:web開(kāi)發(fā)

本文實(shí)例講述了jquery中attr、prop、data區(qū)別與用法。分享給大家供大家參考,具體如下:

在高版本的jquery中獲取標(biāo)簽的屬性,可以使用attr()、prop()、data(),那么這些方法有什么區(qū)別呢?

  • 對(duì)于HTML元素本身就帶有的固有屬性,在處理時(shí),使用prop方法。
  • 對(duì)于HTML元素我們自己自定義的DOM屬性,在處理時(shí),使用attr方法。
  • .data()看作是存取data-xxx這樣DOM附加信息的方法

上面的描述也許有點(diǎn)模糊,舉幾個(gè)例子就知道了。

<a  rel="external nofollow" target="_self" class="btn">百度</a>

這個(gè)例子里<a>元素的DOM屬性有“href、target和class",這些屬性就是<a>元素本身就帶有的屬性,也是W3C標(biāo)準(zhǔn)里就包含有這幾個(gè)屬性,或者說(shuō)在IDE里能夠智能提示出的屬性,這些就叫做固有屬性。處理這些屬性時(shí),建議使用prop方法。

<a href="#" rel="external nofollow" id="link1" action="delete">刪除</a>

這個(gè)例子里<a>元素的DOM屬性有“href、id和action”,很明顯,前兩個(gè)是固有屬性,而后面一個(gè)“action”屬性是我們自己自定義上去的,<a>元素本身是沒(méi)有這個(gè)屬性的。這種就是自定義的DOM屬性。處理這些屬性時(shí),建議使用attr方法。使用prop方法取值和設(shè)置屬性值時(shí),都會(huì)返回undefined值。

再舉一個(gè)例子:

<input id="chk1" type="checkbox" />是否可見(jiàn)
<input id="chk2" type="checkbox" checked="checked" />是否可見(jiàn)

像checkbox,radio和select這樣的元素,選中屬性對(duì)應(yīng)“checked”和“selected”,這些也屬于固有屬性,因此需要使用prop方法去操作才能獲得正確的結(jié)果。

$("#chk1").prop("checked") == false
$("#chk2").prop("checked") == true

如果上面使用attr方法,則會(huì)出現(xiàn):

$("#chk1").attr("checked") == undefined
$("#chk2").attr("checked") == "checked"

說(shuō)說(shuō).data(),我們知道 html 5里面DOM標(biāo)簽可以加以一些data-xxx的屬性,你可以把.data()看作是存取data-xxx這樣DOM附加信息的方法。當(dāng) 然,.data()存取的內(nèi)容不僅是字符串,還可以包含數(shù)組和對(duì)象。從jq1.4.3起, html5 的data-xxx屬性會(huì)自動(dòng)被添加到j(luò)q的data對(duì)象里,比如有下列代碼:

<div data-role="page" data-last-value="43" data-hidden="true" data-options='{"name":"noahlu"}'></div>

下面的等式都成立:

$("div").data("role") === "page";
$("div").data("lastValue") === 43;
$("div").data("hidden") === true;
$("div").data("options").name === "noahlu";

從性能上對(duì)比,.prop() > .data() > .attr(),不同瀏覽器不同版本.data()和.attr()的性能關(guān)系有差異,不過(guò).prop()總是最優(yōu)的。

更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《jQuery常見(jiàn)事件用法與技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery操作json數(shù)據(jù)技巧匯總》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》及《jquery選擇器用法總結(jié)》

希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。

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

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guā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