layui table表格數(shù)據(jù)的新增,修改,刪除,查詢,雙擊獲取行數(shù)據(jù)方式
layui table利用參數(shù)新增,修改,刪除,查詢,雙擊數(shù)據(jù)行獲取本行數(shù)據(jù)等。模塊化使用layui table表格,通過二次封裝實現(xiàn)語法上的解耦使用layui table,使用參數(shù)就可以以及外部的方法調(diào)用即可實現(xiàn)對layui table表格的操作,通過封裝,把更多自主權(quán)交給頁面自定義,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 ? _item = item : '' break; } return _item; }, deleteRowItem: function (id) { var list = this.dataList; for (var i = list.length - 1; i >= 0; i--) { if (list[i].id == id) { list.splice(i, 1); } } this.reloadTable(); }, updateRowItem: function (item,key,callback) { var id = item[key]; //item:ajax獲取的json; key:用于自定義標(biāo)示數(shù)據(jù)行的flag,唯一; var idkey = this.idkey; var tid = this.tid; var arr = this.dataList; for(var ii =0;ii<arr.length;ii++){ var _arr = arr[ii]; var index = ii; if(_arr[idkey] == id){ arr[index] = item; var $div = $("#"+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' ? callback() : ''; }, initialize: function (callback) { var _ = this; layui.use('table', function () { var table = layui.table; _.table = table; typeof callback == 'function' ? callback(_.table) : ''; }) }, bindRowDBclick: function (el, callback) { var _this = this; var $d = $('body'); $d.on('dblclick', "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: '創(chuàng)建時間', field: 'createtime',sort: true}, {title: '狀態(tài)', 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 //雙擊行的回調(diào) }) }); }) //data為行數(shù)據(jù)json table.updateRowItem(data,"id",function(data){ //默認(rèn)更新完的回調(diào) });
代碼僅供參考,涉及到代碼質(zhì)量問題請忽略,這只是一個實現(xiàn)的思路。如需擴(kuò)展其他方法,你可以在原型中添加即可。
以上這篇layui table表格數(shù)據(jù)的新增,修改,刪除,查詢,雙擊獲取行數(shù)據(jù)方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
深入探討JavaScript中parseInt與Number數(shù)字轉(zhuǎn)換方法的區(qū)別
在Javascript編程中,數(shù)字是一種常見的數(shù)據(jù)類型,經(jīng)常需要在不同的情境下進(jìn)行不同類型的操作,本文將深入探討parseInt()和Number()的區(qū)別,通過代碼示例和詳細(xì)解釋,幫助大家更好地理解它們的用途,需要的朋友可以參考下2023-08-08javaScript 關(guān)閉瀏覽器 (不彈出提示框)
如果網(wǎng)頁不是通過腳本程序打開的(window.open()),調(diào)用window.close()腳本關(guān)閉窗口前,必須先將window.opener對象置為null,否則瀏覽器(IE7、IE8)會彈出一個確定關(guān)閉的對話框。2010-01-01微信小程序出現(xiàn)wx.navigateTo頁面不跳轉(zhuǎn)問題的解決方法
這篇文章主要介紹了微信小程序出現(xiàn)wx.navigateTo頁面不跳轉(zhuǎn)問題的解決方法,簡單分析了微信小程序出現(xiàn)wx.navigateTo頁面不跳轉(zhuǎn)情況的原因及相應(yīng)的解決方法,需要的朋友可以參考下2017-12-12通過循環(huán)優(yōu)化 JavaScript 程序
這篇文章主要介紹了通過循環(huán)優(yōu)化 JavaScript 程序,對于提高 JavaScript 程序的性能這個問題,最簡單同時也是很容易被忽視的方法就是學(xué)習(xí)如何正確編寫高性能循環(huán)語句。下面我們來學(xué)習(xí)一下吧2019-06-06動態(tài)加載外部javascript文件的函數(shù)代碼分享
動態(tài)加載外部javascript文件的函數(shù)代碼分享,做個記錄備忘,方便查找。2011-07-07