Layui 的那些事

JavaScript/前端
217
0
0
2024-02-16

前端框架之前接触过不少,目前在用Layui比较顺手;不过也遇到不少雷和坑。这里就分享一下那些雷和坑。。首先说一下表格中有时候ID或NAME是无法取值,只能通过lay-filter指定一个name,然后获得。例如:

<select id="Device_Type" name="Device_Type" lay-filter='Device_Type'>
</select>
<script>
 var postData = data.field;
 var Device_Type =postData.Device_Type;//这样就获得select的值
</script>

这个只是小菜一碟,我们还是直接上点主菜吧。

    layui.use(['jquery', 'form', 'table', 'commonTable', 'common'], function () {
        var $ = layui.jquery,
            form = layui.form,
            table = layui.table, commonTable = layui.commonTable
        common = layui.common;
        var ids = new Array();
        var table_data = new Array();
        toolbarDemo.innerHTML = "<div>当前已经选:<input type='text' id='Cdata' style='width:500px;border:0;background-color:rgba(0,0,0,0);'/></div>";
        commonTable.rendertable({
            elem: '#currentTableId',
            id: 'currentTableId',
            url: '/QAManage/QAWX/GetGridJson',
            defaultToolbar: [],
            skin: 'line',
            limit: 20,
            search: false,
            cols: [[          
                { checkbox: true,width: 60, fixed: true },
                { field: 'Name', title: '姓名', width: 100, sort: true, filter: true },
                { field: 'Telnet', title: '电话', width: 160, sort: true, filter: true },
                { field: 'Memo', title: '备注', width: 180, sort: true, filter: true },
                { field: 'TypeName', title: '角色', width: 80, sort: true, filter: true
                    ,templet: function (d) {
                        switch (d.TypeName) {                          
                            case "B":
                                return ("生产")
                            case "C":
                                return ("售后")
                            case "D":
                                return ("品管")
                            default:
                                return ("全能")
                        }                     
                    }                
                },
                {
                    field: 'DataLevel', title: '当前状态', width: 80,
                    templet: function (d) {
                        return top.clients.dataItems["DataLevel"][d.DataLevel] == null ? "" : top.clients.dataItems["DataLevel"][d.DataLevel];
                    }
                },
                { field: 'F_CreatorTime', title: '注册时间', width: 120, sort: true, filter: { type: 'date[yyyy/MM/dd HH:mm:ss]' } },         
                
            ]],
            done: function (res, curr, count) {               
                $('th[data-field=' + 0 + '] input[type="checkbox"]').prop('disabled',true);
                for (var i = 0; i < res.data.length; i++) {
                    for (var j = 0; j < ids.length; j++) {                       
                        if (res.data[i].Id == ids[j].Id) {                          
                            res.data[i]["LAY_CHECKED"] = 'true';                          
                            var index = res.data[i]['LAY_TABLE_INDEX'];
                            $('.layui-table-fixed-l tr[data-index=' + index + '] input[type="checkbox"]').prop('checked', true);
                            $('.layui-table-fixed-l tr[data-index=' + index + '] input[type="checkbox"]').next().addClass('layui-form-checked');
                        }
                    }
                }
                
                var checkStatus = table.checkStatus('my-table');
                if (checkStatus.isAll) {
                    $('.layui-table-header th[data-field="0"] input[type="checkbox"]').prop('checked', true);
                    $('.layui-table-header th[data-field="0"] input[type="checkbox"]').next().addClass('layui-form-checked');
                }
                //得到所有数据
                console.log(res);
                //得到当前页码
                console.log(curr);
                //得到数据总量
                console.log(count);
            }

        });
        table.on('checkbox(currentTableFilter)', function (obj) {
            var Idata = obj.data;
            console.log(obj.checked); //当前是否选中状态
            console.log(obj.data); //选中行的相关数据           
            console.log(obj.type); //如果触发的是全选,则为:all,如果触发的是单选,则为:one
            //---------------------------------------
            if (obj.checked == true) {
                if (obj.type == 'one') {           
                    ids.push(obj.data);
                } else {
                    for (var i = 0; i < table_data.length; i++) {                 
                        ids.push(table_data[i]);
                    }
                }
            } else {
                if (obj.type == 'one') {
                    for (var i = 0; i < ids.length; i++) {
                        if (ids[i].Id == obj.data.Id) {
                            ids.remove(i);
                        }
                    }
                } else {
                    for (var i = 0; i < ids.length; i++) {
                        for (var j = 0; j < table_data.length; j++) {
                            if (ids[i].Id == table_data[j].Id) {
                                ids.remove(i);
                            }
                        }
                    }
                }
            }
            var Name = "";
            ids.forEach(function (item, index, arr) {
                Name += item.Name+"、"
            });
            $("#Cdata").val(Name);
            //---------------------------------------
        });       
        form.on('submit(CloseBtn)', function (data) {
            var data = table.checkStatus('currentTableId').data;
            if (data.length == 0) {
                common.modalMsg("未选中数据", "warning");
                return;
            };         
            console.log(data)
            var currentWindow = common.parentWindow();//定义父窗口         
            //currentWindow.Auto_STAFF(JSON.stringify(data));
            currentWindow.Auto_STAFF(JSON.stringify(ids));
            
            var index = parent.layer.getFrameIndex(window.name);
            parent.layer.close(index);// 关闭子窗口
        });
        
        // 监听搜索操作
        form.on('submit(data-search-btn)', function (data) {
            //执行搜索重载
            commonTable.reloadtable({
                elem: 'currentTableId',
                curr: 1,
                where: { keyword: data.field.txt_keyword }
            });
            return false;
        });
        wcLoading.close();

    });

//------------------------------
    Array.prototype.remove = function (dx) {
        if (isNaN(dx) || dx > this.length) { return false; }
        for (var i = 0, n = 0; i < this.length; i++) {
            if (this[i] != this[dx]) {
                this[n++] = this[i]
            }
        }
        this.length -= 1
    }

这里就是一个Layui TABLE进行数据展示的代码片段,这里涉及到几个点:1、禁止全选。2、翻页记录。3、父子页数据传输。4、表格格式。这些你看明白没。。还有一个隐藏彩蛋。这里就不公开了。。