中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇示例
來源:易賢網(wǎng) 閱讀:945 次 日期:2015-01-19 13:52:02
溫馨提示:易賢網(wǎng)小編為您整理了“JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇示例”,方便廣大網(wǎng)友查閱!
L

相比attr,prop是1.6.1才新出來的,兩者從中文意思理解,都是獲取/設(shè)置屬性的方法(attributes和properties)。只是,window或document中使用.attr()方法在jQuery1.6之前不能正常運(yùn)行,因?yàn)閣indow和document中不能有attributes。prop應(yīng)運(yùn)而生了。

既然我們想知道他們兩的區(qū)別,最好就看看他們的源代碼,不要被代碼長度所嚇到,我們只看關(guān)鍵的幾句:

attr: function( elem, name, value, pass ) {

var ret, hooks, notxml,

nType = elem.nodeType;

// don't get/set attributes on text, comment and attribute nodes

if ( !elem || nType === 3 || nType === 8 || nType === 2 ) {

return;

}

if ( pass && jQuery.isFunction( jQuery.fn[ name ] ) ) {

return jQuery( elem )[ name ]( value );

}

// Fallback to prop when attributes are not supported

if ( typeof elem.getAttribute === "undefined" ) {

return jQuery.prop( elem, name, value );

}

notxml = nType !== 1 || !jQuery.isXMLDoc( elem );

// All attributes are lowercase

// Grab necessary hook if one is defined

if ( notxml ) {

name = name.toLowerCase();

hooks = jQuery.attrHooks[ name ] || ( rboolean.test( name ) ? boolHook : nodeHook );

}

if ( value !== undefined ) {

if ( value === null ) {

jQuery.removeAttr( elem, name );

return;

} else if ( hooks && "set" in hooks && notxml && (ret = hooks.set( elem, value, name )) !== undefined ) {

return ret;

} else {

elem.setAttribute( name, value + "" );

return value;

}

} else if ( hooks && "get" in hooks && notxml && (ret = hooks.get( elem, name )) !== null ) {

return ret;

} else {

ret = elem.getAttribute( name );

// Non-existent attributes return null, we normalize to undefined

return ret === null ?

undefined :

ret;

}

}

prop方法代碼(jQuery版本1.8.3)

prop: function( elem, name, value ) {

var ret, hooks, notxml,

nType = elem.nodeType;

// don't get/set properties on text, comment and attribute nodes

if ( !elem || nType === 3 || nType === 8 || nType === 2 ) {

return;

}

notxml = nType !== 1 || !jQuery.isXMLDoc( elem );

if ( notxml ) {

// Fix name and attach hooks

name = jQuery.propFix[ name ] || name;

hooks = jQuery.propHooks[ name ];

}

if ( value !== undefined ) {

if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) {

return ret;

} else {

return ( elem[ name ] = value );

}

} else {

if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) {

return ret;

} else {

return elem[ name ];

}

}

}

attr方法里面,最關(guān)鍵的兩行代碼,elem.setAttribute( name, value + “” )和ret = elem.getAttribute( name ),很明顯的看出來,使用的DOM的API setAttribute和getAttribute方法操作的屬性元素節(jié)點(diǎn)。

而prop方法里面,最關(guān)鍵的兩行代碼,return ( elem[ name ] = value )和return elem[ name ],你可以理解成這樣document.getElementById(el)[name] = value,這是轉(zhuǎn)化成JS對象的一個(gè)屬性。

既然明白了原理是這樣,我們來看看一個(gè)例子:

<input type="checkbox" id="test" abc="111" />

$(function(){

el = $("#test");

console.log(el.attr("style")); //undefined

console.log(el.prop("style")); //CSSStyleDeclaration對象

console.log(document.getElementById("test").style); //CSSStyleDeclaration對象

});

el.attr(“style”)輸出undefined,因?yàn)閍ttr是獲取的這個(gè)對象屬性節(jié)點(diǎn)的值,很顯然此時(shí)沒有這個(gè)屬性節(jié)點(diǎn),自然輸出undefined

el.prop(“style”)輸出CSSStyleDeclaration對象,對于一個(gè)DOM對象,是具有原生的style對象屬性的,所以輸出了style對象

至于document.getElementById(“test”).style和上面那條一樣

接著看:

el.attr("abc","111")

console.log(el.attr("abc")); //111

console.log(el.prop("abc")); //undefined

首先用attr方法給這個(gè)對象添加abc節(jié)點(diǎn)屬性,值為111,可以看到html的結(jié)構(gòu)也變了

el.attr(“abc”)輸出結(jié)果為111,再正常不過了

el.prop(“abc”)輸出undefined,因?yàn)閍bc是在這個(gè)的屬性節(jié)點(diǎn)中,所以通過prop是取不到的

el.prop("abc", "222");

console.log(el.attr("abc")); //111

console.log(el.prop("abc")); //222

我們再用prop方法給這個(gè)對象設(shè)置了abc屬性,值為222,可以看到html的結(jié)構(gòu)是沒有變化的。輸出的結(jié)果就不解釋了。

上面已經(jīng)把原理講清楚了,什么時(shí)候用什么就可以自己把握了。

提一下,在遇到要獲取或設(shè)置checked,selected,readonly和disabled等屬性時(shí),用prop方法顯然更好,比如像下面這樣:

<input type="checkbox" id="test" checked="checked" />

console.log(el.attr("checked")); //checked

console.log(el.prop("checked")); //true

console.log(el.attr("disabled")); //undefined

console.log(el.prop("disabled")); //false

顯然,布爾值比字符串值讓接下來的處理更合理。

PS一下,如果你有JS性能潔癖的話,顯然prop的性能更高,因?yàn)閍ttr需要訪問DOM屬性節(jié)點(diǎn),訪問DOM是最耗時(shí)的。這種情況適用于多選項(xiàng)全選和反選的情況。

大家都知道有的瀏覽器只要寫disabled,checked就可以了,而有的要寫成disabled = "disabled",checked="checked",比如用attr("checked")獲取checkbox的checked屬性時(shí)選中的時(shí)候可以取到值,值為"checked"但沒選中獲取值就是undefined。

jq提供新的方法“prop”來獲取這些屬性,就是來解決這個(gè)問題的,以前我們使用attr獲取checked屬性時(shí)返回"checked"和"",現(xiàn)在使用prop方法獲取屬性則統(tǒng)一返回true和false。

那么,什么時(shí)候使用attr(),什么時(shí)候使用prop()?

1.添加屬性名稱該屬性就會(huì)生效應(yīng)該使用prop();

2.是有true,false兩個(gè)屬性使用prop();

3.其他則使用attr();

項(xiàng)目中jquery升級的時(shí)候大家要注意這點(diǎn)!

更多信息請查看IT技術(shù)專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機(jī)網(wǎng)站地址:JS中attr和prop屬性的區(qū)別以及優(yōu)先選擇示例
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn)

版權(quán)所有:易賢網(wǎng)

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久国产剧场电影| 亚洲高清久久久| 欧美一级片在线观看| 日本韩国精品一区二区在线观看| 国产69精品久久久久毛片| 国产乱一区二区| 成人午夜av在线| 99久久精品费精品国产一区二区| 国产电影精品久久禁18| 盗摄精品av一区二区三区| a级精品国产片在线观看| 色婷婷久久久综合中文字幕| 欧美做爰猛烈大尺度电影无法无天| 色诱视频网站一区| 欧美二区三区91| 久久综合九色综合久久久精品综合| 久久久久亚洲综合| 国产精品视频线看| 一级精品视频在线观看宜春院| 亚洲成a人v欧美综合天堂下载| 免费亚洲电影在线| 成人av免费在线播放| 欧美艳星brazzers| 久久奇米777| 亚洲主播在线播放| 精品午夜久久福利影院| 91日韩精品一区| 91 com成人网| 国产精品久久精品日日| 午夜精品久久久久久久久久| 精品一区二区免费视频| 91一区一区三区| 欧美tickling挠脚心丨vk| 中文字幕一区二区5566日韩| 天堂蜜桃91精品| 91同城在线观看| 精品久久久久久久久久久院品网| 国产精品精品国产色婷婷| 美女视频一区二区| 在线观看www91| 日本一区二区三区国色天香| 午夜成人免费视频| 99国产麻豆精品| 欧美精品一区二区三区很污很色的| 亚洲欧美日韩国产成人精品影院| 99精品欧美一区二区三区小说| 在线不卡免费欧美| 亚洲免费三区一区二区| 欧美精品在欧美一区二区少妇| 2024国产精品| 亚洲国产成人精品视频| 成人av电影在线| 久久亚洲一区二区三区明星换脸| 午夜精品久久久久影视| 色狠狠一区二区| 国产精品美女久久久久aⅴ| 国内精品自线一区二区三区视频| 欧美日韩在线三级| 夜夜嗨av一区二区三区四季av | 成人深夜在线观看| 日韩一级大片在线| 日本美女一区二区| 欧美精品tushy高清| 亚洲一区在线视频| 91蜜桃免费观看视频| 国产精品久久久久久久裸模| 国产一区二区三区在线观看精品| 欧美成人精品二区三区99精品| 亚洲成人一二三| 67194成人在线观看| 日韩精品色哟哟| 欧美一区二区三区小说| 肉肉av福利一精品导航| 91精品国产综合久久国产大片| 亚洲国产综合在线| 欧美一区二区三区电影| 蜜桃视频在线一区| 91精品国产色综合久久不卡蜜臀 | 国产无一区二区| 成人app在线观看| 国产视频一区在线播放| 成人性生交大片| 伊人夜夜躁av伊人久久| 欧美在线观看一区| 国产三级三级三级精品8ⅰ区| 亚洲午夜羞羞片| 欧美人动与zoxxxx乱| 免费观看在线综合| 久久伊人中文字幕| 成人综合婷婷国产精品久久 | 奇米在线7777在线精品| 欧美成人vps| 成人黄色软件下载| 亚洲不卡在线观看| 久久久久久久久伊人| 99热99精品| 午夜欧美2019年伦理| 久久影院午夜论| 99re亚洲国产精品| 男女男精品网站| 国产精品三级在线观看| 色拍拍在线精品视频8848| 青青草成人在线观看| 国产精品网站在线| 欧美蜜桃一区二区三区| 国产成人av影院| 同产精品九九九| 中文字幕精品一区二区精品绿巨人 | 一区二区三区中文字幕| 日韩一卡二卡三卡国产欧美| 色综合视频在线观看| 国内久久婷婷综合| 国产精品久久久久永久免费观看| 91免费国产在线观看| 日韩电影在线免费看| 国产精品久久久久一区| 欧美日韩一级片网站| 国产在线精品免费| 亚洲国产日韩a在线播放性色| 久久久美女毛片| 在线不卡a资源高清| 色综合一个色综合| 国产盗摄视频一区二区三区| 亚洲成人动漫在线观看| 亚洲欧美综合网| 精品久久久久久亚洲综合网 | 亚洲综合在线视频| 国产拍揄自揄精品视频麻豆| 91精品国模一区二区三区| 99久久免费视频.com| 国产乱码精品1区2区3区| 日韩精品一卡二卡三卡四卡无卡| 亚洲夂夂婷婷色拍ww47| 欧美亚洲综合色| 国产福利电影一区二区三区| 亚洲高清视频中文字幕| 亚洲啪啪综合av一区二区三区| 久久亚洲影视婷婷| 日韩美女在线视频 | 亚洲午夜激情av| 亚洲精品美腿丝袜| 亚洲精品美国一| 亚洲精品伦理在线| 亚洲最大色网站| 一区二区三区四区av| 一区二区三区欧美日韩| 亚洲欧洲三级电影| 自拍偷自拍亚洲精品播放| 国产精品丝袜一区| 国产精品久久久久婷婷| 中文字幕一区二区视频| 亚洲欧美偷拍另类a∨色屁股| 中文字幕日韩精品一区 | 图片区小说区区亚洲影院| 久久人人97超碰com| 精品国产91乱码一区二区三区 | 国产成a人亚洲| 成人丝袜视频网| 91亚洲男人天堂| 在线欧美日韩精品| 欧美偷拍一区二区| 日韩一区二区在线观看视频| 欧美精品一区二区高清在线观看| 欧美成人aa大片| www日韩大片| 欧美国产精品一区二区| 亚洲日韩欧美一区二区在线| 亚洲一区二区美女| 免费日本视频一区| 粉嫩嫩av羞羞动漫久久久| 国产一区二区在线电影| 首页综合国产亚洲丝袜| 日韩精品视频网| 国产传媒一区在线| 日本精品免费观看高清观看| 欧美一级欧美一级在线播放| 久久综合成人精品亚洲另类欧美| 中文字幕第一区第二区| 亚洲综合成人在线视频| 日韩二区三区在线观看| 丁香天五香天堂综合| 欧美日韩一区国产| 国产精品18久久久久久久久| 国产亚洲成年网址在线观看| 国产片一区二区三区| 一区二区三区四区中文字幕| 日本不卡一区二区| 成人黄色网址在线观看| 欧美日韩国产精品成人| 国产精品五月天| 六月丁香婷婷久久| 99久久国产综合精品女不卡| 欧美一区二区性放荡片| 日本一区二区三区高清不卡| 无吗不卡中文字幕| 色综合久久天天综合网| 国产亚洲欧美中文| 麻豆国产精品官网| 在线观看日韩毛片| 亚洲欧洲另类国产综合|