layui table利用参数新增,修改,删除,查询,双击数据行获取本行数据等。模块化使用layui table表格,通过二次封装实现语法上的解耦使用layui table,使用参数就可以以及外部的方法调用即可实现对layui table表格的操作,通过封装,把更多自主权交给页面自定义,layui:v:2.3.0。感谢layui的作者贤心。
演示效果如下:
以上json显示不完整是录屏的原因,请见谅!
var Table = function(ops){ this.dataList = []; this.table = {}; this.tid = ops.id; } Table.prototype = { getRowItemById: function (id) { var _item = null; var list = this.dataList for (var i = 0; i < list.length; i++) { var item = list[i]; item.id == id "#"+tid).next() var $tr = $div.find('.layui-table-body table.layui-table').find('tr').eq(index); var $tds = $tr.find('td'); for(var i =0;i<$tds.length;i++){ var $td = $tds.eq(i); var $field = $td.attr('data-field'); var $itemValue = item[$field]; var $tdValue = $td.find('div').html(); if($itemValue!=$tdValue){ $td.find('div').html($itemValue); } } continue; } } if (callback) { callback(item) } }, dbClickTableItem: function (callback) { }, addRowItem: function (item) { var list = this.dataList; list.unshift(item); this.reloadTable(); }, reloadTable: function (callback) { var list = this.dataList; this.table.reload(this.tid, { data: list }); }, clearTable: function () { this.dataList = []; this.reloadTable(); }, rederTable: function (ops, callback) { this.table.render(ops); typeof callback == 'function' "tbody tr", function (e) { var target = e; var $index = $(this).index(); var $tr = $(el).next().find("tbody tr")[$index]; if (this == $tr) { var list = _this.dataList; var rowData = list[$index]; callback(target, list, rowData) } else { console.error('Illegal operation without registration\n' + '\n') } }) } }
如何使用:
var table = new Table({id:'mo_table'}); table.initialize(function(tableObj){ var col = [ /*{type:'checkbox',width:80}, {title: '账号', field: 'account'}, {title: '姓名', field: 'name'}, {title: '性别', field: 'sexName'}, {title: '角色', field: 'roleName'}, {title: '部门', field: 'deptName'}, {title: '邮箱', field: 'email',event: 'setSign', style:'cursor: pointer;'}, {title: '电话', field: 'phone'}, {title: '创建时间', field: 'createtime',sort: true}, {title: '状态', field: 'statusName'}, {title: '操作', toolbar:'#cellHandle'}*/ ] var ops = { elem: '#mo_table'//自定义dom ,id:'mo_table' ,data: [] ,cols: [col] ,page: true ,height: 200 } table.rederTable(ops,function () { var row = { "birthday":"2018-08-14 08:00:00", "deptName":"陕西省", "createtime":"2018-08-22 16:14:33", "roleid":"6", "sex":1, "deptid":25, "phone":"15822256985", "sexName":"男", "name":"测试二", "roleName":"代理商管理员", "statusName":"启用", "id":94, "vehicleId":94, "account":"ceshi2", "email":"524585857@qq.com", "status":1, "longitude":'108', "latitude":'38' } table.addRowItem(row) table.bindRowDBclick( '#mo_table', function (evt,list,rowData) { layer.msg(JSON.stringify(rowData)) //doanything here //双击行的回调 }) }); }) //data为行数据json table.updateRowItem(data,"id",function(data){ //默认更新完的回调 });
代码仅供参考,涉及到代码质量问题请忽略,这只是一个实现的思路。如需扩展其他方法,你可以在原型中添加即可。
以上这篇layui table表格数据的新增,修改,删除,查询,双击获取行数据方式就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】