layui 如何动态加载局部页面_layui 学习笔记一:layui table 查询、新增、编辑、删除...

一、table数据的呈现(对应查询)

页面代码:

@{ ViewBag.Title = "TableGrid";}@section styles{ }

TableGrid

@section scripts{ }

TableGrid.js的代码:

; (function () { initQuery();}());function initQuery() { layui.use(['table'], function () { $.post('/Test/TableGridQuery', {}, function (rsp) { var table = layui.table, tableId = 'tblInfo'; table.render({ id: tableId , elem: '#' + tableId , data: rsp.data , cellMinWidth: 80 //全局定义常规单元格的最小宽度,layui 2.2.1 新增 , cols: [[ { field: 'P_NO', width: 100, title: '页面编号' } , { field: 'P_NAME', width: 100, title: '页面名称' } , { field: 'P_ROLE', width: 100, title: '页面角色' } , { field: 'P_DESC', title: '页面说明' } , { field: 'P_URL', width: 280, title: '页面URL' } , { fixed: 'right', width: 120, align: 'center', templet: function () { return ' 编辑 删除'; } } ]] }); //监听数据操作 table.on('tool(' + tableId + ')', function (obj) { var data = obj.data; if (obj.event === 'del') { layer.confirm('真的删除行么', function (index) { layer.msg('删除成功'); obj.del(); layer.close(index); }); } else if (obj.event === 'edit') { showEdit(data); } }); }, 'json'); });}

后台代码 ,对应的是:'/Test/TableGridQuery'

[HttpPost]public JsonResult TableGridQuery(){ ResultClass rc = new ResultClass(); List rc1 = new List(); for (int i = 1; i < 11; i++) { rc1.Add(new ResultClass1() { P_NO = i.ToString(), P_NAME = "页面名称" + i.ToString(), P_ROLE = "页面角色" + i.ToString(), P_DESC = "页面描述" + i.ToString(), P_URL = "页面URL" + i.ToString() }); } rc.data = rc1; rc.code = 0; rc.count = rc1.Count; return Json(rc);}

页面呈现效果:

bf3ce18e131e0de6ea4200c768055572.png

二、新增一条新的记录,并呈现到table中

给新增按钮添加事件:

function initShowAdd() { $('#btnShowAdd').click(function () { var addHtml = '
编号
名称
角色
描述
URL
'; layer.open({ type: 1, title: '新增', content: addHtml, area:['500px','420px'], btn: ['提交', '取消'], yes: function (layIndex) { $('#form1').ajaxSubmit({ success: function (rsp) { if (rsp && rsp.success === true) { layer.close(layIndex); var oldData = layui.table.cache.tblInfo;//获得当前页面的原始数据 oldData.unshift(rsp.data);//在原始数据前添加新添加的数据 layui.table.reload('tblInfo', { data: oldData });//把新处理的数据重新加载一下 layer.msg('提交成功'); } else { if (rsp && rsp.message) { layer.alert(rsp.message); } else { layer.alert('提交失败'); } } } }); } }); });}

显示效果:

3d0f4fa4dfecf1aa2af99d48514c663c.png

三、编辑其中一条记录,并同时更新到table中

新增一个编辑字段:

{ fixed: 'right', width: 120, align: 'center', templet: function () { return ' 编辑 '; }}

监听编辑按钮点击事件:

table.on('tool(' + tableId + ')', function (obj) { var data = obj.data; if (obj.event === 'del') { //删除方法  } else if (obj.event === 'edit') {//监听删除 showEdit(data); //显示编辑对话框 }});

showEdit方法内容如下:

function showEdit(data) { var editHtml = '
编号
名称
角色
描述
URL
'; layer.open({ type: 1, title: '编辑', content: editHtml, area: ['500px', '420px'], btn: ['提交', '取消'], yes: function (layIndex) { $('#form1').ajaxSubmit({ success: function (rsp) { if (rsp && rsp.success === true) { layer.close(layIndex); var oldData = layui.table.cache.tblInfo; var len = oldData.length; //循环数据,找到更新的数据行,直接更新 for (var i = 0; i < len; i++) { if (oldData[i].P_NO == rsp.data.P_NO) { oldData[i] = rsp.data; break; } } //重新加一下数据 layui.table.reload('tblInfo', { data: oldData }); layer.msg('提交成功'); } else { if (rsp && rsp.message) { layer.alert(rsp.message); } else { layer.alert('提交失败'); } } } }); } });}

显示效果:

e4460258ae836c091f414b217eb15744.png

四、删除其中一条记录

新增一个删除字段:

 { fixed: 'right', width: 120, align: 'center', templet: function () { return ' 删除'; } }

监听删除按钮的点击事件

table.on('tool(' + tableId + ')', function (obj) { var data = obj.data; if (obj.event === 'del') {//监听删除 layer.confirm('真的删除行么', function (index) { $.post('/Test/TableGridDelete', { id: data.P_NO }, function (rsp) { if (rsp && rsp.success === true) { layer.msg('删除成功'); obj.del(); layer.close(index); } else { if (rsp && rsp.message) { layer.alert(rsp.message); } else { layer.alert('删除失败'); } } }, 'json'); }); } else if (obj.event === 'edit') { showEdit(data); }});
layui 表格中,可以通过监听复选框的选择来实现批量操作等功能。具体实现步骤如下: 1. 在表格中添加复选框,并设置lay-skin属性为primary,表示使用layui风格的复选框。 ``` <table class="layui-table" lay-data="{...}"> <colgroup> ... <col width="50"> </colgroup> <thead> ... <th lay-data="{field:'checkbox', width:50, templet:'#checkboxTpl'}"></th> </thead> <tbody> ... </tbody> </table> <script type="text/html" id="checkboxTpl"> <input type="checkbox" lay-skin="primary"> </script> ``` 2. 在JavaScript代码中监听复选框的选择事件,可以使用layui的form模块来实现。需要注意的是,由于表格动态生成的,所以需要使用layui的form.render()方法重新渲染表单元素。 ``` layui.use(['table', 'form'], function(){ var table = layui.table, form = layui.form; // 监听复选框选择 table.on('checkbox(test)', function(obj){ console.log(obj.checked); // 当前是否选中状态 console.log(obj.data); // 原始数据 console.log(obj.type); // 类型,如果行选则为:row,如果全选则为:all,如果取消选择则为:uncheck console.log(table.checkStatus('test').data); // 获取选中行的数据 }); // 重新渲染表单元素 form.render(); }); ``` 3. 表格中如果存在分页,则需要在分页时重新渲染表单元素。 ``` table.on('page(test)', function(){ form.render(); }); ``` 以上就是监听表格复选框选择的实现方法。需要注意的是,表格中的复选框必须有唯一的字段名,否则无法在JavaScript代码中获取选中行的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值