我读过一些关于复选框的文章,总是返回一个错误的状态,但没有发现任何关于我自己的问题。复选框allways returned false
所以,这里是脚本:
<script type="text/javascript">
function update_contact(id, name) {
alert("idCont : " + id + "\n nameCKB : " + name + "\n state : "
+ $(this).attr('checked'));
var a = location.pathname.substring(1).split('/')
$.ajax({
url : '@Url.Action("update_contact")',
type : 'POST',
data : {
name : name,
isChecked : $(this).is(':checked'),
idOpp : a[2],
idCont : id
},
success : function(result) {
}
});
};
</script>
这里是复选框代码:
@If mail = False Then
@<input type="checkbox" name="mailed" id="mailed" class="mailed" onclick="update_contact(@item.idContact.toString() , 'mailed')" />
Else
@<input type="checkbox" name="mailed" id="mailed" class="mailed" onclick="update_contact(@item.idContact.toString() , 'mailed')" checked="checked" />
End If
,这里是由服务器生成的代码:
<input name="mailed" id="mailed" class="mailed" onclick="update_contact(1 , 'mailed')" type="checkbox">
在一开始,我使用了一个Html帮手。它是这样返回:
<input id="mailed" name="mailed" onclick="update_contact(1 ,'mailed')" value="true" type="checkbox">
<input name="mailed" value="false" type="hidden">
我虽然是由于第二个输入,它总是返回一个错误的状态。
(抱歉,如果我的英语不好,我不是以英语为母语)
它确实工作得很好! thx很多人。这是我选择的解决方案,因为我能够理解它。 – 2012-04-04 10:15:02
@EliasVanOotegem - '$ .ajax()'部分与它无关。在我的答案的前半部分,我从内联处理函数传递'this',所以'cb'参数将成为复选框。我在答案的后半部分给出的替代方案使用jQuery创建点击处理程序,以便jQuery将“this”设置为单击的元素。 – nnnnnn 2012-04-04 10:43:12
aw ... poppycock,应该仔细看看你的答案......对不起 – 2012-04-04 11:01:13