乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      jQuery -- 函數(shù) prop 和 attr 的區(qū)別

       bleach尸魂界 2014-07-23
      本資源引自:
      jQuery學(xué)習(xí)之prop和attr的區(qū)別_忘塵子_新浪博客
      http://blog.sina.com.cn/s/blog_655388ed01017cnc.html
      ----------------------------------------------------------------------------------------------------------------------------------

      jQuery學(xué)習(xí)之prop和attr的區(qū)別

       
      .prop()
            1、.prop( propertyName ) 獲取匹配集合中第一個(gè)元素的Property的值
      2、給匹配元素集合設(shè)定一個(gè)或多個(gè)屬性
      .prop( propertyName, value )
      .prop( map )
      .prop( propertyName, function(index, oldPropertyValue) )
      .prop()和 .attr()區(qū)別

      下面是關(guān)于jQuery1.6和1.6.1中Attributes模塊變化的描述,以及.attr()方法和.prop()方法的首選使用

      Attributes模塊的變化是移除了attributes和properties之間模棱兩可的東西,
      但是在jQuery社區(qū)中引起了一些混亂,
      因?yàn)樵?.6之前的所有版本中都使用一個(gè)方法(.attr())來處理attributes和properties。
      但是老的.attr()方法有一些bug,很難維護(hù)。
      jQuery1.6.1對Attributes模塊進(jìn)行了更新,并且修復(fù)了幾個(gè)bug。

      elem.checked true (Boolean) Will change with checkbox state
      $(elem).prop("checked") true (Boolean) Will change with checkbox state
      elem.getAttribute("checked") "checked" (String) Initial state of the checkbox; does not change
      $(elem).attr("checked")(1.6) "checked" (String) Initial state of the checkbox; does not change
      $(elem).attr("checked")(1.6.1+) "checked" (String) Will change with checkbox state
      $(elem).attr("checked")(pre-1.6) true (Boolean) Changed with checkbox state

      if ( elem.checked )
      if ( $(elem).prop("checked") )
      if ( $(elem).is(":checked") )

      這三個(gè)都是返回Boolean值。


      為了讓jQuery1.6中的.attr()方法的變化被理解的清楚些,下面是一些使用.attr()的例子,
      雖然在jQuery之前的版本中能正常工作,但是現(xiàn)在必須使用.prop()方法代替:
      jQuery學(xué)習(xí)之prop和attr的區(qū)別

      首先,window或document中使用.attr()方法在jQuery1.6中不能正常運(yùn)行,

      因?yàn)閣indow和document中不能有attributes。

      它們包含properties(比如:location或readyState),

      必須使用.prop()方法操作或簡單地使用javascript原生的方法。

      在jQuery1.6.1中,window和document中使用.attr()將被自動轉(zhuǎn)成使用.prop,而不是拋出一個(gè)錯(cuò)誤。

      其次,checked,selected和前面提到的其它boolean attributes,

      因?yàn)檫@些attributes和其相應(yīng)的properties之間的特殊關(guān)系而被特殊對待。

      基本上,一個(gè)attribute就是以下html中你看到的:

      <input type=”checkbox” checked=”checked”>  

       

      boolean attributes,比如:checked,僅被設(shè)置成默認(rèn)值或初始值。

      在一個(gè)checkbox的元素中,

      checked attributes在頁面加載的時(shí)候就被設(shè)置,

      而不管checkbox元素是否被選中。

       

      properties就是瀏覽器用來記錄當(dāng)前值的東西。

      正常情況下,properties反映它們相應(yīng)的attributes(如果存在的話)。

      但這并不是boolean attriubutes的情況。

      當(dāng)用戶點(diǎn)擊一個(gè)checkbox元素或選中一個(gè)select元素的一個(gè)option時(shí),boolean properties保持最新。

      但相應(yīng)的boolean attributes是不一樣的,正如上面所述,它們僅被瀏覽器用來保存初始值


      $(“:checkbox”).get(0).checked = true;  

      // Is the same as $(":checkbox:first").prop(“checked”, true);  

      在jQuery1.6中,如果使用下面的方法設(shè)置checked:

      $(“:checkbox”).attr(“checked”, true); 

      將不會檢查checkbox元素,因?yàn)樗切枰辉O(shè)置的property,但是你所有的設(shè)置都是初始值。

       

      然而,曾經(jīng)jQuery1.6被釋放出來的時(shí)候,

      jQuery團(tuán)隊(duì)明白當(dāng)瀏覽器僅關(guān)心頁面加載時(shí), 設(shè)置一些值不是特別的有用。

      所以,為了保持向后兼容性和.attr()方法的有用性,

      我們可以繼續(xù)在jQuery1.6.1中使用.attr()方法取得和設(shè)置這些boolean attributes。

       

      最普通的attributes是checked,selected,disabled和readOnly,

      但下面是jQuery1.6.1支持的使用.attr()動態(tài)地取得和設(shè)置boolean attributes/properties的完整列表:


      autofocus, autoplay, async, checked, controls, defer, disabled,  

      hidden, loop, multiple, open, readonly, required, scoped, selected 



      還是建議使用.prop()方法來設(shè)置這些boolean attributes/properties,

      即使這些用例沒有轉(zhuǎn)換成使用.prop()方法,但是你的代碼仍然可以在jQuery1.6.1中正常運(yùn)行。

       下面是一些attributes和properties的列表,

      正常情況下,應(yīng)該使用其對應(yīng)的方法(見下面的列表)來取得和設(shè)置它們。

      面的是首用法,但是.attr()方法可以運(yùn)行在所有的attributes情況下。

      注意:一些DOM元素的properties也被列在下面,但是僅運(yùn)行在新的.prop()方法中


      jQuery學(xué)習(xí)之prop和attr的區(qū)別

      *例如: window.location

      **如果需要在(if needed over) .width()


      .attr()和.prop()都不應(yīng)該被用來取值/設(shè)值。

      使用.val()方法代替(即使使用.attr("value","somevalue") 可以繼續(xù)運(yùn)行,就像1.6之前做的那樣)


      3、首選用法的概述


      .prop()方法應(yīng)該被用來處理 boolean attributes/properties

      以及在html(比如:window.location) 中不存在的 properties。

      其他所有的 attributes(在html中你看到的那些)可以而且應(yīng)該繼續(xù)使用 .attr()  方法來進(jìn)行操作。

      上面的概述已經(jīng)描述的夠清楚了,我也沒有必要再總結(jié)了。


      參考文獻(xiàn):

        本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多