[英]How to not display none when checkbox already checked in filter vanilla javascript?
[英]How to get the value of checked checkbox in vanilla JavaScript?
我正在处理这个片段。 为什么我无法使用 class .shapes
获得任何选中复选框的value
?
document.getElementsByName('shapes').onclick = function() { var checkboxes = document.getElementsByName('shapes')[0].value; console.log(checkbox.value); }
<div class="js-shapes"> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="circle" id="cb-circle"> <label for="cb-circle">Circle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="diamond" id="cb-diamond"> <label for="cb-diamond">Diamond</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="square" id="cb-square"> <label for="cb-square">Square</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="triangle" id="cb-triangle"> <label for="cb-triangle">Triangle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="all" id="cb-all" checked> <label for="cb-all">all Shapes</label> </span> </div>
您可以简单地使用querySelectorAll方法并使用 forEach 方法来检查使用 addEventListener 并在其中change
clicked
的复选框。
编辑:如果您想在选中时获取复选框的值,您可以checked
属性,然后显示其值。
现场演示
let allCheckBox = document.querySelectorAll('.shapes') allCheckBox.forEach((checkbox) => { checkbox.addEventListener('change', (event) => { if (event.target.checked) { console.log(event.target.value) } }) })
<div class="js-shapes"> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="circle" id="cb-circle"> <label for="cb-circle">Circle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="diamond" id="cb-diamond"> <label for="cb-diamond">Diamond</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="square" id="cb-square"> <label for="cb-square">Square</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="triangle" id="cb-triangle"> <label for="cb-triangle">Triangle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="all" id="cb-all" checked> <label for="cb-all">all Shapes</label> </span> </div>
getElementsByName()
返回集合,您必须遍历它们,以便您可以将事件单独附加到它们。 另外,我建议您使用addEventListener()
附加事件:
document.getElementsByName('shapes').forEach(function(chk){ chk.addEventListener('click', function() { if(this.checked){ console.log(this.value); } }); });
<div class="js-shapes"> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="circle" id="cb-circle"> <label for="cb-circle">Circle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="diamond" id="cb-diamond"> <label for="cb-diamond">Diamond</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="square" id="cb-square"> <label for="cb-square">Square</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="triangle" id="cb-triangle"> <label for="cb-triangle">Triangle</label> </span> <span class="ib"> <input type="checkbox" name="shapes" class="shapes" value="all" id="cb-all" checked> <label for="cb-all">all Shapes</label> </span> </div>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.