RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1239115
Accepted
siberian
siberian
Asked:2022-02-02 22:27:31 +0000 UTC2022-02-02 22:27:31 +0000 UTC 2022-02-02 22:27:31 +0000 UTC

选择2 | 超过一定数量时隐藏所选项目

  • 772

Select2与多项选择一起使用,即 用户可以不受限制地选择任意数量的项目。

我该如何做到这一点,以便在选择三个元素时,所有后续的元素(从第四个开始)都隐藏起来并显示隐藏元素的数量?

就像在图片上:

在此处输入图像描述

javascript
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    Victor Gorban
    2022-02-03T00:54:21Z2022-02-03T00:54:21Z

    $(document).ready(function() {
      $('.js-example-basic-multiple').select2();
      $('.js-example-basic-multiple').on('change', function(e) {
        
        let countPlus = $(e.currentTarget).val().length - 3
        
        $('#plusId').remove() // удаляем span с +2.
        if (countPlus > 0) { // добавляем span с +2
          $('ul.select2-selection__rendered[id="select2-mySelect-container"]')
            .append($(`<span id="plusId" class="my-selection-class" >+ ${countPlus}</span>`))
        }
      })
    });
    li.select2-selection__choice:nth-child(n + 4) {
      /* Т.е. 4-й и дальше */
      display: none!important;
    }
    
    span#plusId {
      color: blue;
      margin-left: 5px;
      background: rgb(200, 200, 200);
      padding: 3px 8px;
      border-radius: 5px;
      border: 1px solid rgb(150, 150, 150);
    }
    <html>
    
    <head>
      <link href="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/css/select2.min.css" rel="stylesheet" />
      <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.2.4/jquery.min.js"></script>
    
    
      <script src="https://cdn.jsdelivr.net/npm/select2@4.1.0-rc.0/dist/js/select2.min.js"></script>
    
    </head>
    
    <body>
    
      <select id="mySelect" class="js-example-basic-multiple" name="states[]" multiple="multiple" style="width: 100%">
        <optgroup label="Alaskan/Hawaiian Time Zone ">
          <option value="AK ">Alaska</option>
          <option value="HI ">Hawaii</option>
        </optgroup>
        <optgroup label="Pacific Time Zone ">
          <option value="CA ">California</option>
          <option value="NV ">Nevada</option>
          <option value="OR ">Oregon</option>
          <option value="WA ">Washington</option>
        </optgroup>
        <optgroup label="Mountain Time Zone ">
          <option value="AZ ">Arizona</option>
          <option value="CO ">Colorado</option>
          <option value="ID ">Idaho</option>
          <option value="MT ">Montana</option>
          <option value="NE ">Nebraska</option>
          <option value="NM ">New Mexico</option>
          <option value="ND ">North Dakota</option>
          <option value="UT ">Utah</option>
          <option value="WY ">Wyoming</option>
        </optgroup>
        <optgroup label="Central Time Zone ">
          <option value="AL ">Alabama</option>
          <option value="AR ">Arkansas</option>
          <option value="IL ">Illinois</option>
          <option value="IA ">Iowa</option>
          <option value="KS ">Kansas</option>
          <option value="KY ">Kentucky</option>
          <option value="LA ">Louisiana</option>
          <option value="MN ">Minnesota</option>
          <option value="MS ">Mississippi</option>
          <option value="MO ">Missouri</option>
          <option value="OK ">Oklahoma</option>
          <option value="SD ">South Dakota</option>
          <option value="TX ">Texas</option>
          <option value="TN ">Tennessee</option>
          <option value="WI ">Wisconsin</option>
        </optgroup>
        <optgroup label="Eastern Time Zone ">
          <option value="CT ">Connecticut</option>
          <option value="DE ">Delaware</option>
          <option value="FL ">Florida</option>
          <option value="GA ">Georgia</option>
          <option value="IN ">Indiana</option>
          <option value="ME ">Maine</option>
          <option value="MD ">Maryland</option>
          <option value="MA ">Massachusetts</option>
          <option value="MI ">Michigan</option>
          <option value="NH ">New Hampshire</option>
          <option value="NJ ">New Jersey</option>
          <option value="NY ">New York</option>
          <option value="NC ">North Carolina</option>
          <option value="OH ">Ohio</option>
          <option value="PA ">Pennsylvania</option>
          <option value="RI ">Rhode Island</option>
          <option value="SC ">South Carolina</option>
          <option value="VT ">Vermont</option>
          <option value="VA ">Virginia</option>
          <option value="WV ">West Virginia</option>
        </optgroup>
      </select>
    </body>
    
    </html>

    我将描述算法。

    1 - 隐藏所有不必要的元素

    li.select2-selection__choice:nth-child(n + 4) { /* Т.е. 4-й и дальше */
      display: none!important;
    }
    

    2 - 捕捉更改事件并计数加

    $('.js-example-basic-multiple').on('change', function(e){
      let countPlus = $(e.currentTarget).val().length-3
      console.log(countPlus)
    })
    

    3 - 在所需 select2 的区域中添加或替换所需的跨度。

    $('.js-example-basic-multiple').on('change', function(e){
          let countPlus = $(e.currentTarget).val().length-3
          $('#plusId').remove() // удаляем span с +2.
          if(countPlus>0)
          { // добавляем span с +2
            $('ul.select2-selection__rendered[id="select2-mySelect-container"]')
            .append($(`<span id="plusId" class="my-selection-class" >+ ${countPlus}</span>`))
          }
        })
    

    4 - 不要忘记设计你的跨度

    span#plusId {
      color: blue;
      margin-left: 5px;
      background: rgb(200, 200, 200);
      padding: 3px 8px;
      border-radius: 5px;
      border: 1px solid rgb(150, 150, 150);
    }
    

    用于测试的 select2 取自文档

    • 2

相关问题

  • 第二个 Instagram 按钮的 CSS 属性

  • 由于模糊,内容不可见

  • 弹出队列。消息显示不正确

  • 是否可以在 for 循环中插入提示?

  • 如何将 JSON 请求中的信息输出到数据表 Vuetify vue.js?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5