jQuery convert checkbox selections to array

后端 未结 2 737
闹比i
闹比i 2021-01-27 12:08

I have an HTML like this:

  • 相关标签:
    2条回答
    • 2021-01-27 12:52

      You want to store/send the selected values in one array, right? So why you use unique names then for each checkbox?! ... if they belong together then name them appropriately like so:

          <input type="checkbox" name="pgggo-category-sep[]" value="56">
          <input type="checkbox" name="pgggo-category-sep[]" value="14">
          <input type="checkbox" name="pgggo-category-sep[]" value="8">
          <input type="checkbox" name="pgggo-category-sep[]" value="1">
          <input type="checkbox" name="pgggo-category-sep[]" value="2">
      
          <input type="checkbox" name="pgggo-home-sep[]" value="foo">
          <input type="checkbox" name="pgggo-home-sep[]" value="bar">
          //....
      

      Then they will be sent as an array on submit automatically, no further rearrangement needed ... or if you really want to do it the ajax way still, you can easily get all the ids for the category-checkboxes like so:

          $('[name="pgggo-category-sep[]"]').on('change', function () {
            let values = Array.from($('[name="pgggo-category-sep[]"]:checked'))
              .map(elem => $(elem).val())
          })
      
      0 讨论(0)
    • 2021-01-27 12:59

      I would recommend storing the ids in an object instead of having an array of array. It's easier to work with. Something like this:

      const array = {
        category: [],
        home: [],
      };
      

      Then, you can always transform into the desired form with some array manipulation:

      Object.entries(array).map(([taxomony, id]) => ({taxomony, id}))
      

      Here is the code to update the object when a checkbox is clicked:

      const array = {};
      
      $('[name^="pgggo-"]').on('click', function() {
        const [_, taxonomy, __, attr] = $(this).attr('name').split('-');
        const id = attr.split('[')[0];
        const checked = $(this).prop('checked');
        
        array[taxonomy] = array[taxonomy] || [];
        const index = array[taxonomy].indexOf(id);
        index == -1 ? array[taxonomy].push(id) : array[taxonomy].splice(index, 1);
        
        console.log(array);
      });
      <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
      
      <div class="pgggo-list-taxon">
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-56[]">
                  <div class="icon-box">
                      <div name="development">Development</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-14[]">
                  <div class="icon-box">
                      <div name="food">Food (category)</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-home-sep-14[]">
                  <div class="icon-box">
                      <div name="food">Food (home)</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-8[]">
                  <div class="icon-box">
                      <div name="medical">Medical</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-1[]">
                  <div class="icon-box">
                      <div name="uncategorized">Uncategorized</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-2[]">
                  <div class="icon-box">
                      <div name="wordpress">WordPress</div>
                  </div>
              </label>
        </li>
      </div>


      Or, instead of having to go through the trouble of handling duplicates and states. You can construct the array only when you need to use it:

      $('.sort-button').on('click', function() {
      
        const array = {};
        $('[name^="pgggo-"]').filter(':checked').each(function() {
          const [_, taxonomy, __, attr] = $(this).attr('name').split('-');
          array[taxonomy] = array[taxonomy] || [];
          array[taxonomy].push(attr.split('[')[0]);
        });
        
        console.log(array);
      });
      <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
      
      <div class="pgggo-list-taxon">
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-56[]">
                  <div class="icon-box">
                      <div name="development">Development</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-14[]">
                  <div class="icon-box">
                      <div name="food">Food (category)</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-home-sep-14[]">
                  <div class="icon-box">
                      <div name="food">Food (home)</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-8[]">
                  <div class="icon-box">
                      <div name="medical">Medical</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-1[]">
                  <div class="icon-box">
                      <div name="uncategorized">Uncategorized</div>
                  </div>
              </label>
        </li>
        <li>
          <label>
                  <input type="checkbox" name="pgggo-category-sep-2[]">
                  <div class="icon-box">
                      <div name="wordpress">WordPress</div>
                  </div>
              </label>
        </li>
      </div>
      
      <button class="sort-button">Show!</button> <!-- for demo purposes -->

      0 讨论(0)
    提交回复
    热议问题