1. 程式人生 > >解決redio 再次選中不觸發事件問題

解決redio 再次選中不觸發事件問題

1、操作物件不同: 在jQuery中,attr()函式和prop()函式都用於設定或獲取指定的屬性,它們的引數和用法也幾乎完全相同。不過,在jQuery中,attribute和property卻是兩個不同的概念。attribute表示HTML文件節點的屬性,property表示JS物件的屬性。
<!-- 這裡的id、class、data_id均是該元素文件節點的attribute -->
<div id="message" class="test" data_id="123"></div>
<script type="text/javascript">
<!-- 這裡的name、age、url均是obj的property -->
var obj = { name: "CodePlayer", age: 18, url: "http://www.365mini.com/" };
</script>
2、應用版本不同 attr()是jQuery 1.0版本就有的函式,prop()是jQuery 1.6版本新增的函式。毫無疑問,在1.6之前,你只能使用attr()函式;1.6及以後版本,你可以根據實際需要選擇對應的函式。 3、用於設定的屬性值型別不同 由於attr()函式操作的是文件節點的屬性,因此設定的屬性值只能是字串型別,如果不是字串型別,也會呼叫其toString()方法,將其轉為字串型別。 prop()函式操作的是JS物件的屬性,因此設定的屬性值可以為包括陣列和物件在內的任意型別。 4、其他細節問題(重點!!) 在jQuery 1.6之前,只有attr()函式可用,該函式不僅承擔了attribute的設定和獲取工作,還同時承擔了property的設定和獲取工作。例如:在jQuery 1.6之前,attr()也可以設定或獲取tagName、className、nodeName、nodeType等DOM元素的property。 直到jQuery 1.6新增prop()函式,並用來承擔property的設定或獲取工作之後,attr()才只用來負責attribute的設定和獲取工作。 此外,對於表單元素的checked、selected、disabled等屬性,在jQuery 1.6之前,attr()獲取這些屬性的返回值為Boolean型別:如果被選中(或禁用)就返回true,否則返回false。 但是從1.6開始,使用attr()獲取這些屬性的返回值為String型別,如果被選中(或禁用)就返回checked、selected或disabled,否則(即元素節點沒有該屬性)返回undefined。並且,在某些版本中,這些屬性值表示文件載入時的初始狀態值,即使之後更改了這些元素的選中(或禁用)狀態,對應的屬性值也不會發生改變。 因為jQuery認為:attribute的checked、selected、disabled就是表示該屬性初始狀態的值,property的checked、selected、disabled才表示該屬性實時狀態的值(值為true或false)。 因此,在jQuery 1.6及以後版本中,請使用prop()函式來設定或獲取checked、selected、disabled等屬性。對於其它能夠用prop()實現的操作,也儘量使用prop()函式。