亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS中attr和prop屬性的區別以及優先選擇示例介紹

2019-11-20 14:23:09
字體:
來源:轉載
供稿:網友

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

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

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方法里面,最關鍵的兩行代碼,elem.setAttribute( name, value + “” )和ret = elem.getAttribute( name ),很明顯的看出來,使用的DOM的API setAttribute和getAttribute方法操作的屬性元素節點。
而prop方法里面,最關鍵的兩行代碼,return ( elem[ name ] = value )和return elem[ name ],你可以理解成這樣document.getElementById(el)[name] = value,這是轉化成JS對象的一個屬性。

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

<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,因為attr是獲取的這個對象屬性節點的值,很顯然此時沒有這個屬性節點,自然輸出undefined
el.prop(“style”)輸出CSSStyleDeclaration對象,對于一個DOM對象,是具有原生的style對象屬性的,所以輸出了style對象
至于document.getElementById(“test”).style和上面那條一樣

接著看:

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


首先用attr方法給這個對象添加abc節點屬性,值為111,可以看到html的結構也變了

el.attr(“abc”)輸出結果為111,再正常不過了
el.prop(“abc”)輸出undefined,因為abc是在這個的屬性節點中,所以通過prop是取不到的

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

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

上面已經把原理講清楚了,什么時候用什么就可以自己把握了。

提一下,在遇到要獲取或設置checked,selected,readonly和disabled等屬性時,用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的性能更高,因為attr需要訪問DOM屬性節點,訪問DOM是最耗時的。這種情況適用于多選項全選和反選的情況。

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

jq提供新的方法“prop”來獲取這些屬性,就是來解決這個問題的,以前我們使用attr獲取checked屬性時返回"checked"和"",現在使用prop方法獲取屬性則統一返回true和false。

那么,什么時候使用attr(),什么時候使用prop()?
1.添加屬性名稱該屬性就會生效應該使用prop();
2.是有true,false兩個屬性使用prop();
3.其他則使用attr();
項目中jquery升級的時候大家要注意這點!

以下是官方建議attr(),prop()的使用:

以下是官方建議attr(),prop()的使用:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲韩国青草视频| 亚洲午夜国产成人av电影男同| 欧美精品成人在线| 欧美性猛交xxxx黑人| 亚洲欧美日韩高清| 欧美激情亚洲国产| 91精品国产高清久久久久久91| 精品视频一区在线视频| 国产一区二区黄| 久久久久久久久久久久久久久久久久av| 日本成人激情视频| 国产欧亚日韩视频| 国产在线观看91精品一区| 啪一啪鲁一鲁2019在线视频| 91情侣偷在线精品国产| 狠狠综合久久av一区二区小说| 一区二区三区视频免费在线观看| 欧美午夜片在线免费观看| 国产视频福利一区| 成人av资源在线播放| 国产91精品久久久久| 欧美影院久久久| 日韩欧美国产高清91| 在线视频免费一区二区| 高清欧美性猛交xxxx黑人猛交| 久久久亚洲国产| 欧美孕妇孕交黑巨大网站| 欧美午夜www高清视频| 成人免费淫片aa视频免费| 日韩av综合网站| 欧美国产精品va在线观看| 日韩美女视频在线观看| 久久久久久九九九| 亚洲国产精彩中文乱码av在线播放| 亚洲精品免费网站| 91爱视频在线| 欧美大肥婆大肥bbbbb| 欧美日韩精品在线视频| www.色综合| 色噜噜狠狠狠综合曰曰曰| 欧洲一区二区视频| 一区二区三区视频免费| 日韩中文字幕在线视频| 北条麻妃99精品青青久久| 欧美亚洲另类制服自拍| 久久亚洲精品国产亚洲老地址| 亚洲最大的网站| 91精品国产91久久久久久| 日本一区二区三区四区视频| 日韩一区av在线| 国产91精品网站| 日韩极品精品视频免费观看| 黑人极品videos精品欧美裸| 久久综合亚洲社区| 亚洲第一精品久久忘忧草社区| 精品国产鲁一鲁一区二区张丽| 国产视频亚洲视频| 精品欧美一区二区三区| 国产国产精品人在线视| 精品视频久久久久久久| 怡红院精品视频| 91国产在线精品| 国产一区二区三区毛片| 日韩亚洲成人av在线| 俺去了亚洲欧美日韩| 日韩成人免费视频| 欧美日韩在线一区| 91热福利电影| 国产精品午夜国产小视频| 国产精品一区二区3区| 亚洲jizzjizz日本少妇| 国产精品久在线观看| 综合国产在线视频| 日本久久久久久久久久久| 亚洲一区二区三区在线视频| 精品亚洲男同gayvideo网站| 欧美亚洲一区在线| 亚洲一区二区三区成人在线视频精品| 91极品女神在线| www.欧美三级电影.com| 91久久久国产精品| 亚洲高清一区二| 国产精品99导航| 欧美精品免费在线| 51视频国产精品一区二区| 国产一区二区精品丝袜| 91精品久久久久久久久不口人| 大桥未久av一区二区三区| 日韩免费在线观看视频| 97精品视频在线观看| 亚洲欧美精品伊人久久| 色偷偷偷综合中文字幕;dd| 欧洲美女免费图片一区| 亚洲精品日韩在线| 亲子乱一区二区三区电影| 日本人成精品视频在线| 亚洲综合一区二区不卡| 欧洲午夜精品久久久| 高清日韩电视剧大全免费播放在线观看| 国产成人啪精品视频免费网| 亚洲人成啪啪网站| 国产精品69精品一区二区三区| 国产精品电影观看| 97香蕉超级碰碰久久免费软件| 亚洲自拍偷拍区| 日韩高清电影免费观看完整版| 热99精品只有里视频精品| 成人精品一区二区三区电影黑人| 欧美中文在线字幕| 欧美制服第一页| 日本午夜精品理论片a级appf发布| 欧美激情国产高清| 国产日韩欧美影视| 欧美激情二区三区| 日韩在线中文视频| 亚洲国产三级网| 中文字幕欧美日韩va免费视频| 亚洲无亚洲人成网站77777| 久久99青青精品免费观看| 亚洲精品影视在线观看| 中文一区二区视频| 国产精品看片资源| 亚洲第一二三四五区| 欧美日韩美女在线观看| 精品成人国产在线观看男人呻吟| 中日韩美女免费视频网站在线观看| 亚洲国产精品久久久久秋霞不卡| 亚洲精品一二区| 久久久久国色av免费观看性色| 91国内在线视频| 亚洲欧美激情一区| 最新的欧美黄色| 亚洲国产精品久久久| 久久精品久久久久久国产 免费| 日本欧美国产在线| 91久久精品国产91久久性色| 国产亚洲一区精品| 一区国产精品视频| 久久久久久亚洲精品中文字幕| 久久躁日日躁aaaaxxxx| 中文字幕欧美在线| 亚洲午夜精品视频| 九色成人免费视频| 成人激情视频免费在线| 日韩欧美国产高清91| 91av在线影院| 日韩中文字幕第一页| 亚洲图片欧美日产| 亚洲成人黄色网| 日韩欧美中文在线| 欧美猛交ⅹxxx乱大交视频| 一区二区亚洲欧洲国产日韩| 欧美黑人一级爽快片淫片高清| 在线观看免费高清视频97| 久久九九亚洲综合| 亚洲精品美女在线观看播放| 国产激情久久久| 亚洲国产精品美女| 97精品伊人久久久大香线蕉| 国产在线精品播放| 亚洲欧美在线免费| 国产成人小视频在线观看| 欧美在线www| 亚洲精品一区二区在线|