例如:
option = ["A","B","C","D"];
共四个select,每一个都是下面的结构,option用动态加载
<select name="ft">
<option>A</option>
<option>B</option>
<option>C</option>
<option>D</option>
</select>
当第一个select选中A后,下一个要选择的select点开后只有B,C,D;依次类推。怎么实现呢?可以用jq
select的option元素怎么动态加载呢
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
8条回答 默认 最新
- white_g 2017-07-13 04:49关注
之前答案有朋友支出有bug,这里改一下。
<select style="width:100px" id="s1" class="s" name="ft"> <option value="" disabled selected>请选择</option> <option>A</option> <option>B</option> <option>C</option> <option>D</option> </select> <select style="width:100px" id="s2" class="s"> <option value="" disabled selected>请选择</option> </select> <select style="width:100px" id="s3" class="s"> <option value="" disabled selected>请选择</option> </select> <select style="width:100px" id="s4" class="s"> <option value="" disabled selected>请选择</option> </select> <script> var arr = []; var $select = $('.s'); var index = 0; function se(dom,index){ dom.eq(index++).on('change',function(){ for(var i = index;i<dom.length;i++){ dom.eq(i).html('<option value="" disabled selected>请选择</option>'); } arr[$(this).index()] = $(this).val(); dom.eq(index).html($(this).html()).find('option').each(function(){ var l = $(this).parent().index(); for(var i = 0;i<l;i++){ if($(this).val() === arr[i]){ $(this).hide(); } } }) }); if(index < dom.length){ se(dom,index); } } se($select,0); </script>
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 #MATLAB仿真#车辆换道路径规划
- ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
- ¥15 数据可视化Python
- ¥15 要给毕业设计添加扫码登录的功能!!有偿
- ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
- ¥15 微信公众号自制会员卡没有收款渠道啊
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘