jquery checkbox 勾選的bug問(wèn)題解決方案與分析
在做項(xiàng)目的時(shí)候遇到個(gè)jQuery checkbok復(fù)選框的選中取消的BUG,咨詢(xún)了大神,才鬧明白怎么回事,這里記錄下來(lái),分析給大家。
先上代碼:
<form>
你愛(ài)好的運(yùn)動(dòng)是?<input type="checkbox" id="CheckedAll" />全選/全不選<br />
<input type="checkbox" name="items" value="足球" />足球
<input type="checkbox" name="items" value="籃球" />籃球
<input type="checkbox" name="items" value="羽毛球" />羽毛球
<input type="checkbox" name="items" value="乒乓球" />乒乓球
<br />
<input type="button" id="send" value="提 交" />
</form>
$("#CheckedAll").click(function () {
if ($(this).is(":checked")) {
$("[name=items]:checkbox").attr("checked", true);
} else {
$("[name=items]:checkbox").attr("checked", false);
}
});
第一次執(zhí)行,沒(méi)問(wèn)題,但第二次執(zhí)行就有問(wèn)題了,選擇不了
解決辦法:把a(bǔ)ttr()換成prop()
$("#CheckedAll").click(function () {
if ($(this).is(":checked")) {
$("[name=items]:checkbox").prop("checked", true);
} else {
$("[name=items]:checkbox").prop("checked", false);
}
});
PS:prop()和attr()區(qū)別:
最近在iteye的新聞中看到j(luò)Query已經(jīng)更新到了1.6.1。和之前版本的最大變化是增加了.prop方法。但是.prop()方法和.attr()方法,單從字面上很難區(qū)分。在漢語(yǔ)中properties和attributes都有表示“屬性”的意思。
下面根據(jù)這篇博文(javascript:mctmp(0);),簡(jiǎn)要翻譯了.prop()和.attr()的用法:
1、從1.5.2升級(jí)到1.6.1
通過(guò)介紹新方法.prop()以及.attr()方法的改變,jQuery1.6.1引起了一場(chǎng)關(guān)于attributes和properties之 間有何區(qū)別和聯(lián)系的激烈討論。同時(shí),1.6.1也解決了一些向后兼容性問(wèn)題。當(dāng)從1.5.2升級(jí)到1.6.1時(shí),你不必修改任何attribute代碼。
下面是關(guān)于jQuery1.6和1.6.1中Attributes模塊變化的描述,以及.attr()方法和.prop()方法的首選使用。然而,正如前面所述,jQuery1.6.1允許你使用.attr()方法就像以前它被使用在所有的情況中一樣。
2、發(fā)生了什么變化
Attributes模塊的變化是移除了attributes和properties之間模棱兩可的東西,但是在jQuery社區(qū)中引起了一些混 亂,因?yàn)樵?.6之前的所有版本中都使用一個(gè)方法(.attr())來(lái)處理attributes和properties。但是老的.attr()方法有一 些bug,很難維護(hù)。jQuery1.6.1對(duì)Attributes模塊進(jìn)行了更新,并且修復(fù)了幾個(gè)bug。
特別提到的是,boolean attributes,比如:checked,selected,readonly和disabled在1.6.1中和1.6之前的處理相同。這意味著下面的代碼:
$(“:checkbox”).attr(“checked”, true);
$(“option”).attr(“selected”, true);
$(“input”).attr(“readonly”, true);
$(“input”).attr(“disabled”, true);
甚至是這樣的代碼:
if ( $(“:checkbox”).attr(“checked”) ) { /* Do something */ }
在1.6.1中沒(méi)有必要為了保持之前期望的運(yùn)行結(jié)果而發(fā)生任何改變。
為了讓jQuery1.6中的.attr()方法的變化被理解的清楚些,下面是一些使用.attr()的例子,雖然在jQuery之前的版本中能正常工作,但是現(xiàn)在必須使用.prop()方法代替:
首先,window或document中使用.attr()方法在jQuery1.6中不能正常運(yùn)行,因?yàn)閣indow和document中不能有 attributes。它們包含properties(比如:location或readyState),必須使用.prop()方法操作或簡(jiǎn)單地使用 javascript原生的方法。在jQuery1.6.1中,window和document中使用.attr()將被自動(dòng)轉(zhuǎn)成使用.prop,而不是 拋出一個(gè)錯(cuò)誤。
其次,checked,selected和前面提到的其它boolean attributes,因?yàn)檫@些attributes和其相應(yīng)的properties之間的特殊關(guān)系而被特殊對(duì)待?;旧?,一個(gè)attribute就是以下html中你看到的:
<input type=”checkbox” checked=”checked”>
boolean attributes,比如:checked,僅被設(shè)置成默認(rèn)值或初始值。在一個(gè)checkbox的元素中,checked attributes在頁(yè)面加載的時(shí)候就被設(shè)置,而不管checkbox元素是否被選中。
properties就是瀏覽器用來(lái)記錄當(dāng)前值的東西。正常情況下,properties反映它們相應(yīng)的attributes(如果存在的話(huà))。但 這并不是boolean attriubutes的情況。當(dāng)用戶(hù)點(diǎn)擊一個(gè)checkbox元素或選中一個(gè)select元素的一個(gè)option時(shí),boolean properties保持最新。但相應(yīng)的boolean attributes是不一樣的,正如上面所述,它們僅被瀏覽器用來(lái)保存初始值。
$(“:checkbox”).get(0).checked = true;
// Is the same as $(":checkbox:first").prop(“checked”, true);
在jQuery1.6中,如果使用下面的方法設(shè)置checked:
$(“:checkbox”).attr(“checked”, true);
將不會(huì)檢查checkbox元素,因?yàn)樗切枰辉O(shè)置的property,但是你所有的設(shè)置都是初始值。
然而,曾經(jīng)jQuery1.6被釋放出來(lái)的時(shí)候,jQuery團(tuán)隊(duì)明白當(dāng)瀏覽器僅關(guān)心頁(yè)面加載時(shí),設(shè)置一些值不是特別的有用。所以,為了保持向后兼 容性和.attr()方法的有用性,我們可以繼續(xù)在jQuery1.6.1中使用.attr()方法取得和設(shè)置這些boolean attributes。
最普通的attributes是checked,selected,disabled和readOnly,但下面是jQuery1.6.1支持的使用.attr()動(dòng)態(tài)地取得和設(shè)置boolean attributes/properties的完整列表:
autofocus, autoplay, async, checked, controls, defer, disabled,
hidden, loop, multiple, open, readonly, required, scoped, selected
(譯者注:大部分都是html5新增的屬性)
還是建議使用.prop()方法來(lái)設(shè)置這些boolean attributes/properties,即使這些用例沒(méi)有轉(zhuǎn)換成使用.prop()方法,但是你的代碼仍然可以在jQuery1.6.1中正常運(yùn)行。
下面是一些attributes和properties的列表,正常情況下,應(yīng)該使用其對(duì)應(yīng)的方法(見(jiàn)下面的列表)來(lái)取得和設(shè)置它們。下面的是首用法,但是.attr()方法可以運(yùn)行在所有的attributes情況下。
注意:一些DOM元素的properties也被列在下面,但是僅運(yùn)行在新的.prop()方法中
*例如: window.location
**如果需要在(if needed over) .width()
.attr()和.prop()都不應(yīng)該被用來(lái)取值/設(shè)值。使用.val()方法代替(即使使用.attr("value","somevalue") 可以繼續(xù)運(yùn)行,就像1.6之前做的那樣)
3、首選用法的概述
.prop()方法應(yīng)該被用來(lái)處理boolean attributes/properties以及在html(比如:window.location)中不存在的properties。其他所有的 attributes(在html中你看到的那些)可以而且應(yīng)該繼續(xù)使用.attr()方法來(lái)進(jìn)行操作。
上面的概述已經(jīng)描述的夠清楚了,我也沒(méi)有必要再總結(jié)了。
- 淺談jquery設(shè)置和獲得checkbox選中的問(wèn)題
- 淺談jQuery中的checkbox問(wèn)題
- jquery checkbox無(wú)法用attr()二次勾選問(wèn)題的解決方法
- 淺析jquery與checkbox的checked屬性的問(wèn)題
- 解決jquery操作checkbox火狐下第二次無(wú)法勾選問(wèn)題
- Jquery 獲取checkbox的checked問(wèn)題
- jQuery1.9.1針對(duì)checkbox的調(diào)整方法(prop)
- JQuery觸發(fā)radio或checkbox的change事件
- jQuery判斷checkbox是否選中的3種方法
- jquery判斷checkbox(復(fù)選框)是否被選中的代碼
- jQuery checkbox選中問(wèn)題之prop與attr注意點(diǎn)分析
相關(guān)文章
jQuery源碼分析-05異步隊(duì)列 Deferred 使用介紹
異步隊(duì)列是一個(gè)鏈?zhǔn)綄?duì)象,增強(qiáng)對(duì)回調(diào)函數(shù)的管理和調(diào)用,用于處理異步任務(wù)2011-11-11jQuery?UI旋轉(zhuǎn)器部件Spinner?Widget
這篇文章介紹了jQuery?UI旋轉(zhuǎn)器部件Spinner?Widget,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06jquery.pager.js分頁(yè)實(shí)現(xiàn)詳解
這篇文章主要為大家詳細(xì)介紹了jquery.pager.js分頁(yè)的實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07easyUI使用分頁(yè)過(guò)濾器對(duì)數(shù)據(jù)進(jìn)行分頁(yè)操作實(shí)例分析
這篇文章主要介紹了easyUI使用分頁(yè)過(guò)濾器對(duì)數(shù)據(jù)進(jìn)行分頁(yè)操作,結(jié)合實(shí)例形式詳細(xì)分析了easyUI分頁(yè)過(guò)濾器對(duì)數(shù)據(jù)進(jìn)行分頁(yè)操作具體步驟與相關(guān)操作技巧,需要的朋友可以參考下2020-06-06一個(gè)分享按鈕的插件使用介紹(可擴(kuò)展,內(nèi)附開(kāi)發(fā)制作流程)
前幾天由于工作需要制作一個(gè)分享按鈕,考慮到后續(xù)其他項(xiàng)目可能也會(huì)用到,于是就打算寫(xiě)成插件化2011-09-09jQuery使用數(shù)組編寫(xiě)圖片無(wú)縫向左滾動(dòng)
jQuery編程實(shí)現(xiàn)一組由8幅圖組成的圖片,進(jìn)入網(wǎng)頁(yè)初始時(shí)顯示前面4張,然后自動(dòng)向左滾動(dòng),直到屏幕顯示的是后4張時(shí)停止?jié)L動(dòng),需要的朋友可以參考下2012-12-12