RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 712272
Accepted
pepel_xD
pepel_xD
Asked:2020-08-30 18:04:18 +0000 UTC2020-08-30 18:04:18 +0000 UTC 2020-08-30 18:04:18 +0000 UTC

捆绑两个选择

  • 772

任务是使用javascript绑定2个select,这样满足以下条件:
1.如果select 1中选择了3,则第二个中选择了3,1、2、3option可以选择,0不可以选择.optionoptionoptionoption

2.如果选择1中选择option了2,则第二次选择值为2,1option和option2可供选择,option0和option3不可供选择。

3.如果在select 1中选择了1 - 在第二次select中选择了1 option,其余的都不能选择。

4.如果第1次选择100,第2次选择0 option,其余都无法选择。

任务似乎不难,但有些事情不成功....
当第一个选择100时,第二个中0和1都可用...

function roomsSincGuest(param1, param2) {
  return function (event) {
    var value = param1.value;
    var options = param2.options;
    var optionsLength = options.length;

    for (var i = 0; i < optionsLength; i++) {
      options[i].disabled = true;
      if (+options[i].value === 0 && +value === 100) {
        options[i].selected = true;
        options[i].disabled = false;
      }
      if (options[i].value < value && +options[i].value !== 0) {
        options[i].disabled = false;
      }
      if (options[i].value === value) {
        options[i].selected = true;
        options[i].disabled = false;
      }
    }
  };
}

var first = document.querySelector('#first');
var second = document.querySelector('#second');

first.addEventListener('change', roomsSincGuest(first, second));
<form>
  <select id="first" name="first">
    <option value="1" selected="">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
    <option value="100">100</option>
  </select>

  <select id="second" name="second">
    <option value="3" selected="" >3</option>
    <option value="2" >2</option>
    <option value="1">1</option>
    <option value="0">0</option>
  </select>
</form>

javascript
  • 2 2 个回答
  • 10 Views

2 个回答

  • Voted
  1. Best Answer
    DolphinRamses
    2020-08-30T18:39:40Z2020-08-30T18:39:40Z

    作为一个选项,创建一个将第一个选择的值映射到第二个的对象

    function roomsSincGuest(param1, param2) {
      var optionsMapping = {
        1: [1],
        2: [1, 2],
        3: [1, 2, 3],
        100: [0]
      };
      return function (event) {
        var value = +param1.value;
        var options = param2.options;
        var optionsLength = options.length;
        var availableOptions = optionsMapping[value];
        
        for (var i = 0; i < optionsLength; i++) {
            if(availableOptions.indexOf(+options[i].value) !== -1){
                options[i].disabled = false;
              if(+options[i].value === value || availableOptions.length === 1){
                options[i].selected = true;
              }
            } else {         
              options[i].disabled = true;
            }
        }
      };
    }
    
    var first = document.querySelector('#first');
    var second = document.querySelector('#second');
    
    first.addEventListener('change', roomsSincGuest(first, second));
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
    <form>
      <select id="first" name="first">
        <option value="1" selected="">1</option>
        <option value="2">2</option>
        <option value="3">3</option>
        <option value="100">100</option>
      </select>
    
      <select id="second" name="second">
        <option value="3" selected="" >3</option>
        <option value="2" >2</option>
        <option value="1">1</option>
        <option value="0">0</option>
      </select>
    </form>

    • 3
  2. Suleymani
    2020-08-30T18:51:45Z2020-08-30T18:51:45Z

    最简单的方法:

      function byId(id)
      {
        return document.getElementById(id);
      }
    
      //disable selected items in <select> tag
      function disableItems(element,from, to)
      {
           for(var i =from;i<to;i++)
           {
            console.log(byId(element)[i]);
            byId(element)[i].disabled=true;
           }
      }
    
      //enable all items in <select> tag
      function enableAll(element)
      {
        var item = byId(element);
    
         for(var i =0;i<item.length;i++)
           {
            item[i].disabled=false;
           }
      }
    
    
        function changeDynamicly()
        {
          //change selected index for second <select>
       byId("second").selectedIndex = this.selectedIndex;
    
       //enable all it's items
      enableAll("second");
    
      //also disable items from selected indexto the end..
      disableItems("second",this.selectedIndex+1,byId("second").length);
        }
    
      //attach event listener to change..
        byId("first").addEventListener("change",changeDynamicly);
    
    </script>
    
    • 1

相关问题

Sidebar

Stats

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

    Python 3.6 - 安装 MySQL (Windows)

    • 1 个回答
  • Marko Smith

    C++ 编写程序“计算单个岛屿”。填充一个二维数组 12x12 0 和 1

    • 2 个回答
  • Marko Smith

    返回指针的函数

    • 1 个回答
  • Marko Smith

    我使用 django 管理面板添加图像,但它没有显示

    • 1 个回答
  • Marko Smith

    这些条目是什么意思,它们的完整等效项是什么样的

    • 2 个回答
  • Marko Smith

    浏览器仍然缓存文件数据

    • 1 个回答
  • Marko Smith

    在 Excel VBA 中激活工作表的问题

    • 3 个回答
  • Marko Smith

    为什么内置类型中包含复数而小数不包含?

    • 2 个回答
  • Marko Smith

    获得唯一途径

    • 3 个回答
  • Marko Smith

    告诉我一个像幻灯片一样创建滚动的库

    • 1 个回答
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Алексей Шиманский 如何以及通过什么方式来查找 Javascript 代码中的错误? 2020-08-03 00:21:37 +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
    user207618 Codegolf——组合选择算法的实现 2020-10-23 18:46:29 +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