亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

layui table表格數(shù)據(jù)的新增,修改,刪除,查詢,雙擊獲取行數(shù)據(jù)方式

 更新時間:2019年11月14日 17:44:28   作者:Museions  
今天小編就為大家分享一篇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)文章

  • 原生js+css實現(xiàn)tab切換功能

    原生js+css實現(xiàn)tab切換功能

    這篇文章主要為大家詳細(xì)介紹了原生js+css實現(xiàn)tab切換功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • BootStrap中<li role=

    BootStrap中<li role=

    最近在學(xué)習(xí)bootstrap3.3.5,遇到一個問題搞不清楚<li role="presentation">到底什么含義?今天小編通過本文給大家詳細(xì)介紹下,一起看看吧
    2016-12-12
  • 深入探討JavaScript中parseInt與Number數(shù)字轉(zhuǎn)換方法的區(qū)別

    深入探討JavaScript中parseInt與Number數(shù)字轉(zhuǎn)換方法的區(qū)別

    在Javascript編程中,數(shù)字是一種常見的數(shù)據(jù)類型,經(jīng)常需要在不同的情境下進(jìn)行不同類型的操作,本文將深入探討parseInt()和Number()的區(qū)別,通過代碼示例和詳細(xì)解釋,幫助大家更好地理解它們的用途,需要的朋友可以參考下
    2023-08-08
  • JS 如果改變span標(biāo)簽的是否隱藏屬性

    JS 如果改變span標(biāo)簽的是否隱藏屬性

    JS 如果改變span標(biāo)簽的是否隱藏屬性,大家根據(jù)需要選擇使用。
    2011-10-10
  • javaScript 關(guān)閉瀏覽器 (不彈出提示框)

    javaScript 關(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)問題的解決方法,簡單分析了微信小程序出現(xiàn)wx.navigateTo頁面不跳轉(zhuǎn)情況的原因及相應(yīng)的解決方法,需要的朋友可以參考下
    2017-12-12
  • 通過循環(huán)優(yōu)化 JavaScript 程序

    通過循環(huán)優(yōu)化 JavaScript 程序

    這篇文章主要介紹了通過循環(huán)優(yōu)化 JavaScript 程序,對于提高 JavaScript 程序的性能這個問題,最簡單同時也是很容易被忽視的方法就是學(xué)習(xí)如何正確編寫高性能循環(huán)語句。下面我們來學(xué)習(xí)一下吧
    2019-06-06
  • 微信小程序?qū)崿F(xiàn)簡易的計算器功能

    微信小程序?qū)崿F(xiàn)簡易的計算器功能

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)簡易的計算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 動態(tài)加載外部javascript文件的函數(shù)代碼分享

    動態(tài)加載外部javascript文件的函數(shù)代碼分享

    動態(tài)加載外部javascript文件的函數(shù)代碼分享,做個記錄備忘,方便查找。
    2011-07-07
  • js回溯法計算最佳旅行線路代碼實例

    js回溯法計算最佳旅行線路代碼實例

    這篇文章主要介紹了js回溯法計算最佳旅行線路代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09

最新評論