layui formSelects实现下拉框select多选,并且编辑时候回显

  
1、首先引入formSelects相关配置:引入formSelects-v4的js、css,如果采用第三步的方式引入也是可以的,这里推荐第三步layui.config方式引入。
<link rel="stylesheet" href="/static/layui/css/formSelects-v4.css"/>
<script src="/static/layui/js/formSelects-v4.js"></script>
2、定义一个下拉框
<div class="layui-inline">
                  <label class="layui-form-label">地区</label>
                <div class="layui-input-inline" style="width:350px">
                    <select name="deptId" id="deptId" lay-filter="deptId" lay-verify="required" 
					lay-reqtext="地区不能为空" xm-select="select1" xm-select-height="36px"></select>
                </div>
              </div>  
3、js配置,注意:base: ‘/static/layui/js/’ 一定要与你引入的路径一致,并且写全,不然不起作用
<script>
//全局定义一次, 加载formSelects
layui.config({
    base: '/static/layui/js/' //此处路径请自行处理, 可以使用绝对路径
}).extend({
    formSelects: 'formSelects-v4'
});
//加载模块
layui.use(['jquery', 'formSelects'], function(){
	form = layui.form;
    var layer = layui.layer,
     $ = layui.$;
    var formSelects = layui.formSelects;
    formSelects.data('select1', 'local', {
            arr: [
            {"name": "随笔", "value": 1},
            {"name": "测试", "value": 2},
            {"name": "博客日志", "value": 3}
            ]
        });
    
});
</script>
4、实现从后端查询数据到下拉框,并且编辑时候回显到下拉框
<script>
//全局定义一次, 加载formSelects
layui.config({
    base: '/static/layui/js/' //此处路径请自行处理, 可以使用绝对路径
}).extend({
    formSelects: 'formSelects-v4'
});
//加载模块
	layui.use([ 'jquery', 'formSelects' ], function() {
		form = layui.form;
		var layer = layui.layer, $ = layui.$;
		var formSelects = layui.formSelects;

		var formData = parent.formData;//拿到父页面数据

		$.ajax({
			url : '/stress/taskprogress/getdept',
			dataType : 'json',
			type : 'get',
			success : function(data) {
				var keys = [];
				$('#deptId').empty();
				$('#deptId').append(new Option("请选择机构", ""))
				$.each(data.data, function(index, item) {
					var temp = temp = {
							"name" : item.deptName,
							"value" : item.deptId,
							"children" : fn(item.children)
						//这里需要注意,value应该不同,否则在下拉框选择数据的时候,选择上的数据回事一样的
						}
					if (formData != null) {  //编辑时候回显
						var deptId = formData.deptId.split(",");
						for (var i = 0; i < deptId.length; i++) {
							if (item.deptId == deptId[i]) {
								temp = {
									"name" : item.deptName,
									"value" : item.deptId,
									"selected" : "selected",
									"children" : fn(item.children)
								//这里需要注意,value应该不同,否则在下拉框选择数据的时候,选择上的数据回事一样的
								}
								
							} 
						}
					}

					keys.push(temp);

				});

				//渲染select
				form.render("select");
				formSelects.data("select1", "local", {
					arr : keys
				});

			}
		});

          //递归求字选择项
		function fn(children) {
			var child = [];
			if (children == null) {
				return child;
			}
			$.each(children, function(index, item) {
				var temp = {
					"name" : item.deptName,
					"value" : item.deptId,
					"children" : fn(item.children)
				//这里需要注意,value应该不同,否则在下拉框选择数据的时候,选择上的数据回事一样的
				}
				
				if (formData != null) {
					var deptId = formData.deptId.split(",");
					for (var i = 0; i < deptId.length; i++) {
						if (item.deptId == deptId[i]) {
							temp = {
								"name" : item.deptName,
								"value" : item.deptId,
								"selected" : "selected",
								"children" : fn(item.children)
							//这里需要注意,value应该不同,否则在下拉框选择数据的时候,选择上的数据回事一样的
							}
							
						} 
					}
				}
				
				child.push(temp);
			});
			return child;
		}

	});
</script>
相关文章