基于 layui 扩展的无限级联选择器,支持异步获取数据,以及自定义事件触发。组件使用简单,暴露的参数容易理解,欢迎使用
<div class="layui-form-item">js引用
<label class="layui-form-label">选择框</label>
<div class="layui-input-block">
<input type="text" id="a" class="layui-input" readonly="readonly">
</div>
</div>
layui.use(['form',"jquery","cascader"], function(){
    var $ = layui.jquery;
    var cascader = layui.cascader;
    
    var data = [
        {
            value: 'A',
            label: 'a',
            children: [
                {
                    value: 'AA1',
                    label: 'aa1',
                },
                {
                    value: 'BB1',
                    label: 'bb1'
                }
            ]
        },
        {
            value: 'B',
            label: 'b',
        }
    ]
    var cas=cascader({
        elem: "#a",
        data: data,
        // url: "/aa",
        // type: "post",
        // triggerType: "change",
        // showLastLevels: true,
        // where: {
        //     a: "aaa"
        // },
        value: ["A", "AA1"],
        success: function (data) {
            console.log(data);
        }
    });
    cas.reload({})  // 重载
});cascader参数说明1. elem:input容器cascader函数
2. data:需要的静态数据,类型为数组,
3. url:异步获取的数据,类型为数组,(data与url两个参数二选一)
4. type:异步获取的方式,默认get,可省略
5. where:异步传入的参数,可省略
6. triggerType:触发方式,不填或其他都为click,可选参数"change",即鼠标移入触发
7. showLastLevels:输入框是否只显示最后一级,默认false,即全显示
8. value:传入的初始值,类型为数组,值为data的value值
9. success:回调函数,选择完成之后的回调函数,返回值为value数组
1. cas.reload(): 可重新渲染数据在线demo