search

Home  >  Q&A  >  body text

javascript - check and uncheck in js

Problem description: There are multiple checkboxes, implemented using input simulation. I want to put the corresponding value into the array when clicked, and delete the corresponding value in the array when unchecked. How to achieve this?

迷茫迷茫2786 days ago1136

reply all(4)I'll reply

  • 阿神

    阿神2017-05-19 10:44:57

    I have done something similar before. The general idea is: loop checkbox, when the current checkbox is checked, set the current checked status and then take the input value and pass it into the array array.push($(this).val()), Unchecking is the same operation. In the end, just remove the input value.

    reply
    0
  • 我想大声告诉你

    我想大声告诉你2017-05-19 10:44:57

    <p class="parent">
        <input index='0' type="checkbox">
        <input index='1' type="checkbox">
        <input index='2' type="checkbox">
      </p>
      <script>
      //存储数据
      var arrValue = [];
    
      //有一个父级包住所有的input['checkbox']
      document.querySelector('.parent').addEventListener('change', function(event) {
        var tar = event.target;
        if (tar.getAttribute('type') === 'checkbox') {
          //如果改变的是checkbox
          var index = tar.getAttribute('index'),
              onoff = true,//判断有没有存在的值
              data = {
                  index:index,
                  value:tar.value
              }
    
          arrValue.forEach(function(v,i,arr){
              if(v.index === index){
                  //获取到目标
                  arr.splice(i,1);
                  onoff = false;
                  return;
              }
          })
    
          if(onoff){
              //如果没有存在的,就添加
              arrValue.push(data);
          }
    
        }
      }, false);
      </script>
    
    `

    reply
    0
  • 为情所困

    为情所困2017-05-19 10:44:57

    Change your thinking, write a checkbox change event, and get all selected items (checked=true), that’s it

    <html>
        <head>
            <title>
                title
            </title>
            <meta name="author" content="zsdroid">
        </head>
        <body>
            <input type="checkbox" class="radioSelect" value="1">1
            <input type="checkbox" class="radioSelect" value="2">2
            <input type="checkbox" class="radioSelect" value="3">3
        </body>
        <script>
            //获取所有选中项
            var GetSelectedItems = function()
            {
                var list = new Array;
                document.querySelectorAll('.radioSelect').forEach(function(item)
                    {
                        //如果选中,放入list
                        if(item.checked)
                        list.push(item.value);
                    });
                return list;
            }
            //checkbox的change事件
            document.querySelectorAll('.radioSelect').forEach(function(item)
                {
                    item.addEventListener('change', function(event)
                        {
                            console.log(GetSelectedItems());
                        });
                });
        </script>
    </html>

    reply
    0
  • 淡淡烟草味

    淡淡烟草味2017-05-19 10:44:57

    I was bored and wrote something for a while, and copied @shangguanyuanheng's code. I don't understand why I don't need to use native jquery, and the title doesn't say it can't be used, right?

    code:

    <html>
        <head>
            <title>
                title
            </title>
            <meta name="author" content="zsdroid">
        <script id="jquery_183" type="text/javascript" class="library" src="jquery-1.8.3.min.js"></script>
        </head>
        <body>
            <input type="checkbox" class="radioSelect" value="1">1
            <input type="checkbox" class="radioSelect" value="2">2
            <input type="checkbox" class="radioSelect" value="3">3
        </body>
        <script>
                Array.prototype.remove = function(val) {
                    var index = this.indexOf(val);
                    if (index > -1) {
                    this.splice(index, 1);
                    }
                };
                let arr=[];
                $('.radioSelect').bind("change",(e)=>{
                    var target=$(e.target);
                    var value=target.val();
                    let ischecked=target.is(":checked");
                    if(ischecked){
                        //push
                        arr.push(value);
                    }else{
                        //remove
                        arr.remove(value);
                    }
                        console.info(arr);
                }
            );
          
        </script>
    </html>

    Online trial

    Hope to make bricks~

    reply
    0
  • Cancelreply