layui教程---table

Posted zouhong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了layui教程---table相关的知识,希望对你有一定的参考价值。

 layui.config({
        base: "${ctx}/static/js/"
    }).use([‘form‘, ‘layer‘, ‘jquery‘, ‘common‘,‘element‘, ‘table‘, ‘laytpl‘], function () {
        $ = layui.$;
        var $ = layui.$,
            form = layui.form,
            common = layui.common,
            laydate = layui.laydate,
            element = layui.element,
            table = layui.table,
            laytpl = layui.laytpl,
            layer = layui.layer;
        var content = ‘content‘;
        common.getOptionsByCode(‘PLATE‘, ‘identifyVehicleColorId‘,‘‘,‘车牌颜色‘);
         var loading = layer.load(1, {shade: [0.9, ‘#fff‘]});

        /**重置*/
        $("#rev-btn").click(function () {
            $("input").val(‘‘);
            $(‘select‘).each(function (i, j) {
                $(j).find("option:selected").attr("selected", false);
                $(j).find("option").first().attr("selected", true);
                form.render(‘select‘)
            })
        });
        /**用户表格加载*/
        table.render({
            elem: ‘#tableList‘,
            url: ‘${ctx}/vehicleFlow/flowQry.do‘,
            id: ‘userTableId‘,
            method: ‘post‘,
            height: ‘full-140‘,
            skin: ‘row,line‘,
            size: ‘sm‘,
            defaultToolbar: [],
            cols: [[
                {field:‘index‘, title: ‘序号‘,align:‘center‘,width: ‘4%‘,type:‘numbers‘},
                {field:‘passId‘, title: ‘通行标识ID‘,align:‘center‘,width: ‘12%‘},
                {field:‘carNoColor‘, title: ‘车牌号(颜色)‘, align: ‘center‘,width: ‘10%‘ },
                {field:‘enStation‘, title: ‘入口站‘, align: ‘center‘,width: ‘10%‘ },
                {field:‘exStation‘, title: ‘出口站‘, align: ‘center‘,width: ‘10%‘ },
                {field:‘enStationTime‘, title: ‘入口时间‘, align: ‘center‘,width: ‘15%‘ },
                {field:‘exStationTime‘, title: ‘出口时间‘, align: ‘center‘,width: ‘15%‘ },
                {field:‘passSectionsNum‘, title: ‘经过路段数‘, align: ‘center‘,width: ‘6%‘ },
                {field:‘chargeAmount‘, title: ‘收费金额‘, align: ‘center‘,width: ‘8%‘ },
                {field: ‘operate‘, title: ‘操作‘, align: ‘center‘, width: ‘12%‘ ,toolbar:‘#optBar‘  }

            ]],
            page: true,
            done: function (res, curr, count) {
                common.resizeGrid();
                common.addEventOnBody();
                layer.close(loading);
            }
        });

        /**查询*/
        $(".search-button").click(function () {
            var loading = layer.load(1, {shade: [0.9, ‘#fff‘]});
            //监听提交
            form.on(‘submit(searchFilter)‘, function (data) {
                table.reload(‘userTableId‘, {
                    where: data.field,
                    height: ‘full-140‘,
                    page: true,
                    done: function (res, curr, count) {
                        common.resizeGrid();
                        layer.close(loading);
                    }
                });
                return false;
            });
        });


<!--工具条 -->
<script type="text/html" id="optBar">
    <a class="layui-btn layui-btn-xs opt-item" lay-event="tool_opt" >查看详情</a>
</script>

toolbar - 绑定工具条模板

table.render({
  cols: [[
    {field:‘id‘, title:‘ID‘, width:100}
    ,{fixed: ‘right‘, width:150, align:‘center‘, toolbar: ‘#barDemo‘} //这里的toolbar值是模板元素的选择器
  ]]
});
 
等价于:
<th lay-data="{field:‘id‘, width:100}">ID</th>
<th lay-data="{fixed: ‘right‘, width:150, align:‘center‘, toolbar: ‘#barDemo‘}"></th>

下述是 toolbar 对应的模板,它可以存放在页面的任意位置:

    <script type="text/html" id="barDemo">
      <a class="layui-btn layui-btn-xs" lay-event="detail">查看</a>
      <a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
      <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
      
      <!-- 这里同样支持 laytpl 语法,如: -->
      {{#  if(d.auth > 2){ }}
        <a class="layui-btn layui-btn-xs" lay-event="check">审核</a>
      {{#  } }}
    </script>
     
    注意:属性 lay-event="" 是模板的关键所在,值可随意定义。
          

接下来我们可以借助 table模块的工具条事件,完成不同的操作功能:

    //监听工具条 
    table.on(‘tool(test)‘, function(obj){ //注:tool 是工具条事件名,test 是 table 原始容器的属性 lay-filter="对应的值"
      var data = obj.data; //获得当前行数据
      var layEvent = obj.event; //获得 lay-event 对应的值(也可以是表头的 event 参数对应的值)
      var tr = obj.tr; //获得当前行 tr 的 DOM 对象(如果有的话)
     
      if(layEvent === ‘detail‘){ //查看
        //do somehing
      } else if(layEvent === ‘del‘){ //删除
        layer.confirm(‘真的删除行么‘, function(index){
          obj.del(); //删除对应行(tr)的DOM结构,并更新缓存
          layer.close(index);
          //向服务端发送删除指令
        });
      } else if(layEvent === ‘edit‘){ //编辑
        //do something
        
        //同步更新缓存对应的值
        obj.update({
          username: ‘123‘
          ,title: ‘xxx‘
        });
      } else if(layEvent === ‘LAYTABLE_TIPS‘){
        layer.alert(‘Hi,头部工具栏扩展的右侧图标。‘);
      }
    });
          


done - 数据渲染完的回调

无论是异步请求数据,还是直接赋值数据,都会触发该回调。你可以利用该回调做一些表格以外元素的渲染。

    table.render({ //其它参数在此省略
      done: function(res, curr, count){
        //如果是异步请求数据方式,res即为你接口返回的信息。
        //如果是直接赋值的方式,res即为:{data: [], count: 99} data为当前页数据、count为数据总长度
        console.log(res);
        
        //得到当前页码
        console.log(curr); 
        
        //得到数据总量
        console.log(count);
      }
    });
          

表格重载

很多时候,你需要对表格进行重载。比如数据全局搜索。以下方法可以帮你轻松实现这类需求(可任选一种)。

技术图片

 

 

 示例1:自动化渲染的重载

table.reload(‘idTest‘, {
  url: ‘/api/table/search‘
  ,where: {} //设定异步数据接口的额外参数
  //,height: 300
});
      

示例2:方法级渲染的重载

    //所获得的 tableIns 即为当前容器的实例
    var tableIns = table.render({
      elem: ‘#id‘
      ,cols: [] //设置表头
      ,url: ‘/api/data‘ //设置异步接口
      ,id: ‘idTest‘
    }); 
     
    //这里以搜索为例
    tableIns.reload({
      where: { //设定异步数据接口的额外参数,任意设
        aaaaaa: ‘xxx‘
        ,bbb: ‘yyy‘
        //
      }
      ,page: {
        curr: 1 //重新从第 1 页开始
      }
    });
    //上述方法等价于
    table.reload(‘idTest‘, {
      where: { //设定异步数据接口的额外参数,任意设
        aaaaaa: ‘xxx‘
        ,bbb: ‘yyy‘
        //
      }
      ,page: {
        curr: 1 //重新从第 1 页开始
      }
    }); //只重载数据
          
//监听行单击事件(双击事件为:rowDouble)
  table.on(‘row(test)‘, function(obj){
    var data = obj.data;
    
    layer.alert(JSON.stringify(data), {
      title: ‘当前行数据:‘
    });
    
    //标注选中样式
    obj.tr.addClass(‘layui-table-click‘).siblings().removeClass(‘layui-table-click‘);
  });
  

 

参考layui:https://www.layui.com/doc/modules/table.html#onrowtool

                https://www.layui.com/demo/table/onrow.html

以上是关于layui教程---table的主要内容,如果未能解决你的问题,请参考以下文章

layui实现table加载的示例代码

layui的table使用

layui使用table.reload()后保持滚动条

layui table cols有没有回调函数?

记录layui的table绑定事件与选项卡的使用

Layui——选项卡加载table数据列表