我正在尝试通过点击li
来查看复选框。问题是,只有当有人点击label
而不是完整li
时才会选中该复选框(这是因为li
的宽度超过了label
!
<ul>
<li><input id="a1" type="checkbox"><label for="a1">1</label></li>
<li><input id="a2" type="checkbox"><label for="a2">2</label></li>
<li><input id="a3" type="checkbox"><label for="a3">3</label></li>
</ul>
我尝试使用下面的Javascript解决此问题,但它仍然只在单击label
时检查复选框。
$("li").click(function(e) {
var checked = !$(this).children("input").first().prop("checked");
$(this).children("input").first().prop("checked", checked);
$(this).toggleClass("selected", checked);
});
注意:如果可能的话,我想避免使用Javascript和Jquery。
答案 0 :(得分:4)
您不需要脚本。您可以使用li
打包复选框和所有label
内容。给出标签display:block
,这样它就会“占用”li
的整个宽度,这样li
就可以点击(比如,不是真的)
label {
display:block;
}
<ul>
<li><label for="a1"><input id="a1" type="checkbox">1</label></li>
<li><label for="a2"><input id="a2" type="checkbox">2</label></li>
<li><label for="a3"><input id="a3" type="checkbox">3</label></li>
</ul>
答案 1 :(得分:0)
试试这个;
添加class =&#34; myclass&#34;到ul。
$('ul.myclass li input').click(
function(event){
event.stopPropagation();
});
答案 2 :(得分:0)
我的解决方案确实使用直接JS,但它在HTML中内联,所以没有太复杂。
<li onclick="document.getElementById('a1').checked = !document.getElementById('a1').checked;">
<input id="a1" type="checkbox" onclick="event.stopPropagation();"><label for="a1">1</label>
</li>
答案 3 :(得分:0)