下拉树选择
1.下载地址:https://fly.layui.com/extend/treeSelect/
//下拉选择
layui.config({ base: '/lib/layuiadmin/lib/extend/' // js地址 }).extend({ treeSelect: 'treeSelect' }); layui.use(['treeSelect', 'form'], function () { var treeSelect = layui.treeSelect; treeSelect.render({ // 选择器 elem: '#ParentIdTree', // 数据 data: "../OrganizationManage/GetOrganizationSelect", // 异步加载方式:get/post,默认get type: 'get', async: false, // 占位符 placeholder: '请选择上级父节点', // 是否开启搜索功能:true/false,默认false search: true, // 点击回调 click: function (d) { $("#ParentId").val(d.current.id); }, // 加载完成后的回调函数 success: function (d) { if ($("#ParentId").val() != "") treeSelect.checkNode('ParentIdTree', $("#ParentId").val()); } }); });
返回书结构
封装递归方法
////// 下拉树 /// /// /// /// public static List ToTreeSelect (this List items) where T : ILayuiTree { return GetTreeSelectChildren(items, null); } /// /// 递归实现下拉树 /// /// 所有数据 /// 子数据的父ID /// private static List GetTreeSelectChildren (List items, string parentId) where T : ILayuiTree { var treeSelects = new List (); var subItems = items.Where(o => o.ParentId == parentId); foreach (var item in subItems) { treeSelects.Add(new LayuiTreeSelect() { id = item.Id, name = item.Name, children = GetTreeSelectChildren(items, item.Id), }); } return treeSelects; }
泛型约束使用注意
这样类型参数约束,.NET支持的类型参数约束有以下五种:
where T : struct | T必须是一个结构类型
where T : class T必须是一个类(class)类型
where T : new() | T必须要有一个无参构造函数
where T : NameOfBaseClass | T必须继承名为NameOfBaseClass的类
where T : NameOfInterface | T必须实现名为NameOfInterface的接口
ILayuiTree接口类
public interface ILayuiTree { string Id { get; set; } string Name { get; set; } string Icon { get; set; } string ParentId { get; set; } string Url { get; set; } bool Checked { get; set; } }