1. 程式人生 > >checkbox屬性checked="checked"已有,但卻不顯示打勾的解決辦法

checkbox屬性checked="checked"已有,但卻不顯示打勾的解決辦法

在做許可權管理的時候,做了一個功能,就是當勾選欄目,把所有的許可權全勾上。剛開始使用瞭如下程式碼:

function check(id,check) {
	if (check) {
		$("." + id).find("input[type='checkbox']").attr("checked", true);
	} else {
		$("." + id).find("input[type='checkbox']").attr("checked", false);
	}
}

第一遍勾選和取消是有效的,但是第二遍以後就沒反應了,查看了屬性,發現checked屬性一直存在,但是沒顯示勾。就考慮移除checked屬性看看。

function check(id,check) {
	if (check) {
		$("." + id).find("input[type='checkbox']").attr("checked", true);
	} else {
		$("." + id).find("input[type='checkbox']").removeAttr("checked");
	}
}

這次看到checked屬性勾上有了,取消就沒了,可是問題還是沒解決,還是第二遍以後就沒反應了。看Jquery手冊上說1.6以下版本在IE6使用JQuery的removeAttr方法刪除disabled是無效的。解決的方法就是使用$("XX").prop("disabled",false);課時我都用1.10的版本了,不管那麼多了,死馬當活馬醫就用這個方法試試。

function check(id,check) {
	if (check) {
		$("." + id).find("input[type='checkbox']").prop("checked", true);
	} else {
		$("." + id).find("input[type='checkbox']").removeAttr("checked");
	}
}

寫成這樣,問題解決,我估計手冊上說的修復只修復了一遍,之後還是會出問題,所以最保險的還是用prop。