翼度科技»论坛 编程开发 JavaScript 查看内容

【前端】Layui动态数据表格拖动排序

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
目的:使用Layui的数据表格,拖动行进行排序。
使用插件:layui-soul-table 和 Layui
1.layui-soul-table文档:https://soultable.yelog.org/#/zh-CN/component/start/install
2.layui文档:Layui table模块 | 数据表格 | datatable - 在线演示
结合Layui并参看layui-soul-table官方教程,写的比较详细页比较简单。
实现效果:可以拖动行进行排序,可以搜索

一、下载layui-soul-table

把下载好的文件放到项目中,比如说放到public文件夹下的/ext/soulTable/下,下载的内容很多,不需要全部都放到目录下,只需要把用到拷贝进来就行,如下图

二、使用

因为需求是实现拖动排序,所以只用到了soulTable.slim.js
  1. layui.config({
  2.     base: '/ext/',   // 第三方模块所在目录
  3.     version: 'v1.6.4' // 插件版本号
  4. }).extend({                        
  5.     soulTable: 'soulTable/soulTable.slim'    // 模块
  6. });
复制代码
三、Layui实际使用

1、html代码
  1. 有几个需要注意的地方:
  2. 1、搜索按钮的lay-filter要一致
  3. 2、lay-event对应下面的toolbar
复制代码
  
  1.    
  2.     <form  class="layui-form layui-form-pane"  style="float:left">
  3.         
  4.             <label class="layui-form-label">视频名称</label>
  5.             
  6.                 <input type="text" name="filename" placeholder="视频名称" autocomplete="off" class="layui-input" value="">
  7.             
  8.             <button class="layui-btn layui-btn-normal" lay-submit lay-filter="demo-table-search">
  9.                 <i class="fa fa-search" aria-hidden="true"></i> 搜 索
  10.             </button>
  11.         
  12.     </form>
  13.    
  14.    
  15.     <table id="myTable" lay-filter="test" id="test"></table>
  16.    
  17.    
  18.    
  19.    
复制代码
2、JS代码
  1. 1、引入soulTable,注意路径,我存放的路径是在/public/ext/soulTable/下
  2. 2、extend引入的模块可以根据自己需求添加
  3. 3、table.render()下的id和elem要和上面HTML中的table的id一致
  4. 4、rowDrag下的done里面的是拖动时触发的事件,可以从这里获取拖动行的数据信息,并在这里更新数据库
  5. 5、cols里的就是列名,列名对应上就行
  6. 6、done下的代码是刷新拖动之后的表格的,勿删
  7. 7、搜索提交:其实就是数据表格的重载,可以参考Layui官网,我这里为了后端接收方便,所有和Layui官网的示例有些出入。注意lay-filter监听要一致,其中table.reload下的myTable也要和上面HTML的一致,用于标识重载的表格
  8. 8、监听行工具事件:根据event的不同,处理不同的业务
复制代码
  1. layui.config({
  2.     base: '/ext/',   // 第三方模块所在目录
  3.     version: 'v1.6.4' // 插件版本号
  4. }).extend({                        
  5.     soulTable: 'soulTable/soulTable.slim'    // 模块
  6. }); layui.use(['element', 'layer','form','table','soulTable'], function(){    var $ = layui.jquery    ,layer = layui.layer    ,element = layui.element    ,form = layui.form    ,table = layui.table    ,soulTable = layui.soulTable;     var myTable = table.render({        id: 'myTable'        ,elem: '#myTable'        ,url: 'videoquery'        // ,toolbar: '#myBar'        ,height: 500        ,rowDrag: {done: function(obj) {            // 完成时(松开时)触发            // 如果拖动前和拖动后无变化,则不会触发此方法            // console.log(obj.row) // 当前行数据            // console.log(obj.cache) // 改动后全表数据            // console.log(obj.oldIndex) // 原来的数据索引            // console.log(obj.newIndex) // 改动后数据索引             var row_id = obj.row.id      // 当前id            var row_sort = obj.newIndex+1         // 拖动后的排序             // console.log(row_id)            // console.log(row_sort)             $.ajax({                url:'/teacher/video/upsort',                type:'POST',                dataType:'JSON',                data:{id:row_id,sort:row_sort},                success:function (res) {                    console.log(res)                    layer.msg(res.message, {                      time: 2000 //2秒关闭(如果不配置,默认是3秒)                    }, function(){                      //do something                        location.reload()                    });                }            })        }}        ,totalRow: true        ,cols: [[            {field: 'filename', title: '视频名称', width: '20%', fixed: 'left'},            {field: 'kejian', title: '关联课件', width: '30%', height:'auto', fixed: 'left'},            {fixed: 'right', title:'预览', toolbar: '#preview', width:'20%'},            {fixed: 'right', title:'操作', toolbar: '#barDemo', width:'30%'}        ]]        ,page: true        ,done: function () {            soulTable.render(this)        }    });     // 搜索提交  form.on('submit(demo-table-search)', function(data){    var field = data.field; // 获得表单字段    // console.log(field)    // 执行搜索重载    table.reload('myTable', {          page: {        curr: 1 // 重新从第 1 页开始      },      where: field // 搜索的字段    });    return false; // 阻止默认 form 跳转  });     //监听行工具事件    table.on('tool(test)', function(obj){        var data = obj.data;        //console.log(obj)        if(obj.event === 'preview'){            // console.log(data)            // 预览              window.open(data.path);        }else if(obj.event === 'del'){            // console.log(data.id)            layer.confirm('确定删除吗?', {icon: 3, title:'提示'}, function(index){                  $.ajax({                        url:"del",                    type:"POST",                    dataType:"JSON",                    data:{id:data.id},                    success:function (res) {                        if (res.code == 200) {                            layer.msg(res.message);                            obj.del();                        }else{                            layer.msg(res.message);                            return false;                        }                    }                })              });        } else if(obj.event === 'edit'){            // console.log(data.id)          window.location.href='edit.html?id='+data.id;        }    }); });  
复制代码
3、PHP后台代码

主要是添加了搜索,返回的是JSON数据
  1. public function videoquery()
  2. {
  3.     $map = array();
  4.     $page = input('page');  //页码
  5.     $limit = input('limit');  //分页
  6.     $filename = trim(input('param.filename'));
  7.     if (!empty($filename)) {
  8.         $map['video.filename'] = array('like',"%$filename%");
  9.     }
  10.    
  11.     // 列表
  12.     $data= model('Video')->getList($this->tid,$map,$page,$limit);
  13.     // 个数
  14.     $count = model('Kejian')->gerKejianCount($this->tid,$map);
  15.     $result = array(
  16.        'code'=>0,
  17.        'msg'=>'',
  18.        'count'=>$count,
  19.        'data'=> $data
  20.     );
  21.     return $result;
  22. }
复制代码
 

来源:https://www.cnblogs.com/zxf100/p/17680261.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具