javascript - 复选框 : Enable button if checkbox checked

标签 javascript jquery html

在我的页面中有一个模式窗口,在模式中我有2个复选框,我希望所有选中的复选框都启用发送按钮并更改背景颜色(如果禁用bgcolor为灰色,否则bgcolor为红色)。我怎样才能做到正确?

HTML:

<form action="" method="POST" class="send-modal-data">
    <input type="text" id="send_email" name="subscribe-email" class="modal-input" placeholder="Email *" required="required">
    <div class="checkboks custom-sq vdc-cb-area">
        <input type="checkbox" id="box4" name="vdc-modal-cb" class="checked-checkbox"/>
        <label for="box4" class="checkboks-text d-flex align-center"><?php echo the_field('vdc_checkbox_txt', 'option'); ?></label>
    </div>
    <div class="checkboks custom-sq vdc-cb-area">
        <input type="checkbox" id="box7" name="vdc-modal-cb" class="checked-checkbox" />
        <label for="box7" class="checkboks-text d-flex align-center"><?php echo the_field('vdc_checkbox_text_2', 'option'); ?></label>
    </div>
    <div class="success-msg">
        <div class="msg"></div>
    </div>
    <input type="submit" name="subscribe-form" id="vdc-send-modal" class="danger-btn send-subscribe" disabled="disabled" value="<?php echo the_field('lets_get_started', 'option'); ?>"></input>
</form>

JS:

var checks = document.getElementsByName('vdc-modal-cb');
var checkBoxList = document.getElementById('vdc-cb-area');
var sendbtn = document.getElementById('vdc-send-modal');

function allTrue(nodeList) {
  for (var i = 0; i < nodeList.length; i++) {
    if (nodeList[i].checked === false) return false;
  }
  return true;
}

checkBoxList.addEventListener('click', function(event) {
  sendbtn.disabled = true;
  if (allTrue(checks)) sendbtn.disabled = false;
  console.log(123);
});

注意:我从堆栈溢出中获取了这个示例,但它对我不起作用

最佳答案

1.您应该使用getElementsByClassName来获取具有相同类的元素。

2.要将 eventListener 添加到类元素,您应该迭代这些元素。

var checks = document.getElementsByName('vdc-modal-cb');
var checkBoxList = document.getElementsByClassName('vdc-cb-area');
var sendbtn = document.getElementById('vdc-send-modal');

function allTrue(nodeList) {
  for (var i = 0; i < nodeList.length; i++) {
    if (nodeList[i].checked === false) return false;
  }
  return true;
}

for (var i = 0; i < checkBoxList.length; i++) {
  checkBoxList[i].addEventListener('click', function(event) {
    sendbtn.disabled = true;
    if (allTrue(checks)) sendbtn.disabled = false;
  });
}

关于javascript - 复选框 : Enable button if checkbox checked,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59137617/

相关文章:

jquery - 在 ajax 请求中重新加载数据

html - DIV 中没有自动换行

javascript - 如何使用 JQuery 检索无序列表的 li 标签并将这些标签放入数组中?

html - AngularJS - 动态更新 ng 类名称

javascript - 如何更改日历在文本框上的可见性单击

javascript - Javascript 数组对多个键进行排序是否会破坏之前的排序?

javascript - 如何从动态创建的按钮传递参数?

javascript - 如何将 FormData(HTML5 对象)转换为 JSON

Javascript - 如何使用数组中的元素设置按钮的值?

jquery - 100% 客户端 jquery 购物车