我想检查收音机.以下都不起作用:
[编辑]
$('selector').attr('checked','checked');
$('selector').attr('checked',true);
Run Code Online (Sandbox Code Playgroud)
以下代码中的两个alert()分别显示"1"和"a".我的期望是第二个警告()显示"b".
Opera会检查其浏览器中的第二个单选框,但其元素检查器dragonfly显示DOM未更改.
[结束编辑]
在发布此问题之前,我已阅读过常见问题解答:
帮助将不胜感激!
TIA
xhtml页面和代码如下:
<!DOCTYPE html
PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
<title>Weird Behavior</title>
<script type="text/javascript" src="scripts/jquery.js"/>
<script type="text/javascript">
function clickme(){
alert($('input[name="myname"][value="b"]').length);
$('input[name="myname"][value="b"]').attr('checked','checked');
$('#b').attr('checked',true);
alert($('input[name="myname"][checked]').val());
};
</script>
</head>
<body>
<form action="">
<fieldset>
<legend>Why check is not switched?</legend>
<input type="radio" name="myname" value="a" id="a" checked="checked"/>A
<input type="radio" name="myname" value="b" id="b"/>B
</fieldset>
</form>
<p>
<button type="button" onclick="clickme()">click me</button>
</p>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)
Fiz*_*han 131
$('.checkbox').attr('checked',true);
Run Code Online (Sandbox Code Playgroud)
而是使用
$('.checkbox').prop('checked',true);
$('.checkbox').prop('checked',false);
Run Code Online (Sandbox Code Playgroud)
Ale*_*yne 17
使用jQuery,永远不要使用内联onclick
javascript.保持不引人注目.这样做,并onclick
完全删除.
另外,请注意:checked
在最后一行中使用伪选择器.原因是因为一旦页面加载,表单元素的html和实际状态可能不同.打开Web检查器,您可以单击其他单选按钮,HTML仍将显示第一个选中.:checked
相反,选择器会过滤实际检查的元素,而不管html的开头是什么.
$('button').click(function() {
alert($('input[name="myname"][value="b"]').length);
$('input[name="myname"][value="b"]').attr('checked','checked');
$('#b').attr('checked',true);
alert($('input[name="myname"]:checked').val());
});
Run Code Online (Sandbox Code Playgroud)
tra*_*ace 10
$('.checkbox').prop('checked',true);
$('.checkbox').prop('checked',false);
Run Code Online (Sandbox Code Playgroud)
...与jquery1.9.1完美配合
为什么不试试IS?
$('selector').is(':checked') /* result true or false */
Run Code Online (Sandbox Code Playgroud)
看一下FAQ: jQuery .is() 嘱咐我们;-)