首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >根据第一次使用Javascript切换三个选项菜单

根据第一次使用Javascript切换三个选项菜单
EN

Stack Overflow用户
提问于 2022-07-16 16:33:13
回答 2查看 46关注 0票数 1

当我单击另一个,前面的应该是不可见的。

如果选择A,然后选择B,然后选择C,则内部HTML应该只显示C内容。有人能帮我做这件事吗?

实际上,我需要一个jsp表单,在那里我可以在选项之间切换,然后获取参数。我被困在这上面了。

代码语言:javascript
运行
复制
function myFunction() {
  if (document.getElementById("abcid").selectedIndex == "1") {
    document.getElementById("aid").innerHTML = "A:<select>" +
      "<option>Select-</option>" +
      "<option>Alex</option>" +
      "<option>Jack</option>" +
      "</select>";
  } else if (document.getElementById("abcid").selectedIndex == "2") {
    document.getElementById("bid").innerHTML = "B:<select>" +
      "<option>Select-</option>" +
      "<option>US</option>" +
      "<option>Australia</option>" +
      "<option>India</option>" +
      "</select>";
  } else if (document.getElementById("abcid").selectedIndex == "3") {
    document.getElementById("cid").innerHTML = "C:<select>" +
      "<option>Select-</option>" +
      "<option>Blue</option>" +
      "<option>Green</option>" +
      "<option>Red</option>" +
      "</select>";
  }
}
代码语言:javascript
运行
复制
<table>
  <tr>
    <td>ABC:
      <select id="abcid" onchange="myFunction()">
        <option>Select-</option>
        <option>A</option>
        <option>B</option>
        <option>C</option>
      </select>
    </td>
  </tr>
  <tr>
    <td id="aid"></td>
  </tr>
  <tr>
    <td id="bid"></td>
  </tr>
  <tr>
    <td id="cid"></td>
  </tr>
</table>

EN

回答 2

Stack Overflow用户

发布于 2022-07-16 17:34:13

一种更简单的方法.

代码语言:javascript
运行
复制
const
  selectABC = document.querySelector('#abcid')
, trSelect2 = document.querySelector('tr.noDisplay')
, label_2   = trSelect2.querySelector('label')
, select_2  = trSelect2.querySelector('select')
, selCases =
  { A: { label: 'Aaa', sels:[ {k: '1', v:'Alex' }, {k: '2', v:'Jack'      }                       ] }
  , B: { label: 'Bbb', sels:[ {k: 'w', v:'US'   }, {k: 'x', v:'Australia' }, {k: 'y', v:'India' } ] }
  , C: { label: 'Ccc', sels:[ {k: '$', v:'Blue' }, {k: '£', v:'Green'     }, {k: '§', v:'Red'   } ] }
  };
  
selectABC.onchange = e =>
  {
  select_2.length        = 1
  select_2.selectedIndex = 0
  label_2.textContent    = selCases[selectABC.value].label
  selCases[selectABC.value].sels.forEach(({k,v}) => select_2.add( new Option(v,k)) )
  trSelect2.classList.remove('noDisplay')
  }
代码语言:javascript
运行
复制
.noDisplay { display: none; }
代码语言:javascript
运行
复制
<table>
  <tr>
    <td>
      <label>ABC:</label>
      <select id="abcid">
        <option value="" selected disabled>Select-</option>
        <option value="A">A</option>
        <option value="B">B</option>
        <option value="C">C</option>
      </select>
    </td>
  </tr>
  <tr class="noDisplay">
    <td>
      <label></label>
      <select>
        <option value="" selected disabled>Select-</option>
      </select>
    </td>
  </tr>
</table>

票数 0
EN

Stack Overflow用户

发布于 2022-07-19 14:01:57

在这里,您可以找到一个解决方案:

代码语言:javascript
运行
复制
var select = document.querySelector("#abcid");

select.addEventListener('input', function (event) {
  var conditionals = document.querySelectorAll('.conditional');
  var selectedValue = select.value;
  var selectedSub = document.querySelector("#abcid-"+select.value);

  for(var i=0; i<conditionals.length; i++){
    if(selectedSub.id === conditionals[i].id){
      conditionals[i].classList.remove('hide');      
      conditionals[i].classList.add('show');      
    }else{
      conditionals[i].classList.add('hide');      
      conditionals[i].classList.remove('show');      
    }
  }

});
代码语言:javascript
运行
复制
.hide{
  display:none;
}

.show{
  display:block;
}
代码语言:javascript
运行
复制
ABC:
  <select id="abcid">
    <option>Select-</option>
    <option>A</option>
    <option>B</option>
    <option>C</option>
  </select>

  <select id="abcid-A" class="conditional hide">
    <option>Select-A</option>
    <option>A-A</option>
    <option>A-B</option>
    <option>A-C</option>
  </select>

  <select id="abcid-B" class="conditional hide">
    <option>Select-B</option>
    <option>B-A</option>
    <option>B-B</option>
    <option>B-C</option>
  </select>

  <select id="abcid-C" class="conditional hide">
    <option>Select-C</option>
    <option>C-A</option>
    <option>C-B</option>
    <option>C-C</option>
  </select>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73005942

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档