posts - 8,  comments - 6,  trackbacks - 0

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

          之前看網(wǎng)上對比兩者的文章,更是列出一個表來區(qū)分什么標簽下使用prop,什么標簽下使用attr,原諒我是懶惰的人,最害怕要背的東西,所以只有自己想想辦法了。

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

          attr方法代碼(jQuery版本1.8.3)

          • 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é)點
          而prop方法里面,最關(guān)鍵的兩行代碼,return ( elem[ name ] = value )和return elem[ name ],你可以理解成這樣document.getElementById(el)[name] = value,這是轉(zhuǎn)化成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對象
          • });
          1. el.attr(“style”)輸出undefined,因為attr是獲取的這個對象屬性節(jié)點的值,很顯然此時沒有這個屬性節(jié)點,自然輸出undefined
          2. el.prop(“style”)輸出CSSStyleDeclaration對象,對于一個DOM對象,是具有原生的style對象屬性的,所以輸出了style對象
          3. 至于document.getElementById(“test”).style和上面那條一樣

          我們接著看:

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

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

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

          我們再接著來:

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

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

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

          提一下,在遇到要獲取或設(shè)置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屬性節(jié)點,訪問DOM是最耗時的。這種情況適用于多選項全選和反選的情況。

          posted on 2015-01-21 14:33 ♂游泳的魚 閱讀(1853) 評論(1)  編輯  收藏

          FeedBack:
          # re: [JS]jQuery中attr和prop方法的區(qū)別[未登錄]
          2015-01-27 15:03 | 星情
          分析得不錯  回復(fù)  更多評論
            

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           

          <2015年1月>
          28293031123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          留言簿(1)

          隨筆分類

          隨筆檔案

          文章分類

          文章檔案

          搜索

          •  

          最新評論

          閱讀排行榜

          主站蜘蛛池模板: 安国市| 邮箱| 宣化县| 无极县| 汉沽区| 怀柔区| 六枝特区| 永州市| 仁布县| 阿鲁科尔沁旗| 贞丰县| 即墨市| 双桥区| 吴旗县| 江都市| 阜城县| 松溪县| 清流县| 四平市| 景泰县| 米林县| 平阴县| 三门县| 民丰县| 衡阳县| 卫辉市| 盐城市| 拉萨市| 凤阳县| 两当县| 张家港市| 玛多县| 宁武县| 简阳市| 包头市| 云梦县| 隆昌县| 麻江县| 盐亭县| 仁布县| 班玛县|