layui之select的option叠加问题的解决方法


Posted in Javascript onMarch 08, 2018

小编我在使用layui,在select的地方遇到了坑,select里的值居然无法清空,select里的option还有叠加问题,为了解决这个问题,也达到我的功能,我研究了下,让有同样需求的小伙伴不踩坑,特贴上我的源码:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>layui-下拉框联动测试</title>
 <link rel="stylesheet" href="layui/css/layui.css" rel="external nofollow" >
</head>
<body>
<div id="wrap">
 <div class="layui-form" lay-filter="merchantForm">
 <div class="layui-form-item">
 <label class="layui-form-label">选择框</label>
 <div class="layui-input-block">
  <select name="city" lay-verify="required" id="test1" lay-filter="test1">
  <option value="0">时间</option>
  <option value="1">金额</option>
  </select>
 </div>
 </div>
 <div class="layui-form-item">
 <label class="layui-form-label">选择框</label>
 <div class="layui-input-block">
  <select name="city" lay-verify="required" id="test2" lay-filter="test2">
  <option value="">请选择规则名称</option>
  </select>
 </div>
 </div>
</div> 
<button id="btn">确定</button>
</body>
<script src="layui/layui.all.js"></script>
<script src="layui/jquery-1.8.3.min.js"></script>
<script>
//后台传过来的数据
var data=[
 {unitType:0,ruleName:'时间规则11',amount:1100,money:1100},
 {unitType:0,ruleName:'时间规则12',amount:1200,money:1200},
 {unitType:0,ruleName:'时间规则13',amount:1300,money:1300},
 {unitType:1,ruleName:'金额规则21',amount:2100,money:2100},
 {unitType:1,ruleName:'金额规则22',amount:2200,money:2200},
 {unitType:1,ruleName:'金额规则23',amount:2300,money:2300},
];
//初始化默认为时间类型以及对应的时间规则
layui.use('form', function(){
 var form = layui.form;
  $('#test2').html('');
  var html='';
  $.each(data,function(i,e){
   if(e.unitType==0)
    html+=`<option data-type="${e.unitType}">${e.ruleName}</option>`;
  })
  $('#test2').append(html);
  form.render('select'); 
})
//动态二级联动
layui.use('form', function(){
 var form = layui.form;
  form.on('select(test1)', function(obj){
  $('#test2').html('');
  var html='';
  if(obj.value==0){
   $.each(data,function(i,e){
    if(e.unitType==obj.value)
     html+=`<option data-type="${e.unitType}">${e.ruleName}</option>`;
   })
   $('#test2').append(html);
  }else if(obj.value==1){
   $.each(data,function(i,e){
    if(e.unitType==obj.value)
    html+=`<option data-type="${e.unitType}">${e.ruleName}</option>`;
   })
   $('#test2').append(html);
  }
  form.render('select');
 });
})
//二级联动完毕后获取对应的规则数据
$('#btn').click(function(){
 var thisValue=data.find((v)=>v.ruleName==$('#test2').val());
 console.log(thisValue); 
})
</script>
</html>

以上这篇layui之select的option叠加问题的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
学习JavaScript事件流和事件处理程序
Jan 25 Javascript
关于JS中match() 和 exec() 返回值和属性的测试
Mar 21 Javascript
基于BootStrap Metronic开发框架经验小结【四】Bootstrap图标的提取和利用
May 12 Javascript
JS学习之表格的排序简单实例
May 16 Javascript
微信小程序实战之自定义模态弹窗(8)
Apr 18 Javascript
Angular.JS中指令ng-if的注意事项小结
Jun 21 Javascript
基于Vue实例对象的数据选项
Aug 09 Javascript
vue select二级联动第二级默认选中第一个option值的实例
Jan 10 Javascript
微信小程序仿微信运动步数排行(交互)
Jul 13 Javascript
iview在vue-cli3如何按需加载的方法
Oct 31 Javascript
jQuery实现的别踩白块小游戏完整示例
Jan 07 jQuery
layui table 复选框跳页后再回来保持原来选中的状态示例
Oct 26 Javascript
vue2.0 axios跨域并渲染的问题解决方法
Mar 08 #Javascript
解决Vue 通过下表修改数组,页面不渲染的问题
Mar 08 #Javascript
Vue.js实现图片的随意拖动方法
Mar 08 #Javascript
JS字符串去除连续或全部重复字符的实例
Mar 08 #Javascript
实战node静态文件服务器的示例代码
Mar 08 #Javascript
vue.js或js实现中文A-Z排序的方法
Mar 08 #Javascript
vue.js移动数组位置,同时更新视图的方法
Mar 08 #Javascript
You might like
初探PHP5
2006/10/09 PHP
PHP里8个鲜为人知的安全函数分析
2014/12/09 PHP
PHP简单选择排序算法实例
2015/01/26 PHP
php 使用html5实现多文件上传实例
2016/10/24 PHP
php对接java现实加签验签的实例
2016/11/25 PHP
FCK调用方法..
2006/12/21 Javascript
window.showModalDialog使用手册
2007/01/11 Javascript
最佳的addEvent事件绑定是怎样诞生的
2011/10/24 Javascript
js 表单提交后按钮变灰的实例代码
2013/08/16 Javascript
js使用DOM操作实现简单留言板的方法
2015/04/10 Javascript
jquery实现从数组移除指定的值
2015/06/24 Javascript
js实现统计字符串中特定字符出现个数的方法
2016/08/02 Javascript
常用的几个JQuery代码片段
2017/03/13 Javascript
Vue下的国际化处理方法
2017/12/18 Javascript
vue2.0+vue-dplayer实现hls播放的示例
2018/03/02 Javascript
详解Vue源码学习之callHook钩子函数
2018/07/25 Javascript
浅谈VUE单页应用首屏加载速度优化方案
2018/08/28 Javascript
解决layui 表单元素radio不显示渲染的问题
2019/09/04 Javascript
vuex + keep-alive实现tab标签页面缓存功能
2019/10/17 Javascript
vue.config.js常用配置详解
2019/11/14 Javascript
Python实现连接两个无规则列表后删除重复元素并升序排序的方法
2018/02/05 Python
对python 匹配字符串开头和结尾的方法详解
2018/10/27 Python
[原创]Python入门教程5. 字典基本操作【定义、运算、常用函数】
2018/11/01 Python
详解如何用django实现redirect的几种方法总结
2018/11/22 Python
tensorflow之变量初始化(tf.Variable)使用详解
2020/02/06 Python
python lambda的使用详解
2021/02/26 Python
通过canvas转换颜色为RGBA格式及性能问题的解决
2019/11/22 HTML / CSS
阿拉伯书店:Jamalon
2019/07/24 全球购物
美体小铺波兰官方网站:The Body Shop波兰
2019/09/03 全球购物
介绍一下JMS编程步骤
2015/09/22 面试题
同学聚会欢迎辞
2014/01/14 职场文书
公司经理聘任书
2014/03/29 职场文书
土地转让协议书
2014/09/27 职场文书
上班迟到检讨书范文
2015/05/06 职场文书
导游词之西湖雷峰塔
2019/09/18 职场文书
SQL之各种join小结详细讲解
2021/08/04 MySQL