Layui给数据表格动态添加一行并跳转到添加行所在页的方法


Posted in Javascript onAugust 20, 2018

Layui是一个前端 UI 框架,该框架风格优雅,但由于发布时间较短,很多功能并没有提供实现。

笔者在使用Layui的数据表格的时候,需求是这样的:当点击添加按钮的时候,就在数据表格最后动态添加一行。上述功能官方并没有给出实现,需要自己手动解决。

解决思路及方案

简单分析:根据需求——动态添加一行,首先想到的是利用JS/jQuery操作DOM对象实现在数据表格table中手动添加一个tr,但由于数据表格的每一行的每一个单元格都有其样式,因此,要想动态添加的一行与Layui数据表格渲染出来的每一行样式及功能一样,就必须给tr设置和渲染出来的每一行一样的样式,利用jQuery去完成这个添加这样一个tr工程量实在太大了,因此需要换一种方案。

数据表格中的原始数据:查看Layui官方文档,采用方法渲染或者自动渲染的方式去生成数据表格时,数据表格中的数据是通过直接赋值的方式或者异步加载的方式获得原始的数据。

直接赋值方式原始的数据其实就是一个对象数组,如[{}, {}, {}, {}, …]。

异步加载方式原始的数据发请求从后端取,然后后端返回给前端的一个json对象,这里要求后端返回给前端的json对象要符合Layui数据表格能渲染的格式,Layui数据表格默认支持的后端返回给前端的json对象格式如下,各个属性具体描叙参照官方文档:

{
  code: 0, 
  msg: "", 
  count: 1000, 
  data: [] 
 }

数据表格的重载:数据表格重载可以将新拿到的原始数据重新渲染到数据表格中,Layui提供的是方法是table.reload(ID, options)

ID:table的id属性值

options:为Layui数据表格的基础参数,具体参照官方文档

下面给出针对原始数据是通过直接赋值的方式、采用方法渲染的数据表格动态添加一行的思路及解决方法

思路:通过上述讲解,动态添加一行其实可以转换为:

拿到数据表格中的所有数据后,也就是拿到一个对象数组,在那个对象数组最后添加一个与拿到的对象数组中对象相同、但其所有属性的属性值为空的一个空对象。(那数据表格中所有数据可参照我的另一篇Layui数据表格之获取表格中所有的数据)

利用table.reload(ID, options)方法将添加了一个“空对象”的数组重新加载渲染到数据表格即可。

跳转到动态添加行所在页,只要设置table.reload(ID, options)中options的page基础参数即可,将page参数的curr属性值设置为动态添加行所在页页码(页码根据数据表格每页显示的记录数以及添加了一行后数据表格中总的记录数自己算)即可。2、3步代码如下():

//获取每页显示的记录数、当前记录总数,计算新添加的记录在第几页
var totalRecord = tableContent.length;
var pageSize = $(".layui-laypage-limits").find("select").val();
if($.type(pageSize) == "string"){
 pageSize = parseInt(pageSize);
}

var currPageNo = Math.ceil(totalRecord / pageSize);
console.log("每页显示的记录数:"+pageSize+" 类型:"+$.type(pageSize)+" 总的记录数:"+totalRecord+" 类型:"+$.type(totalRecord)
  +" 新增行所在页码:"+currPageNo+" 类型:"+$.type(currPageNo));

// 重载表格并跳转到最后修改或者添加数据的那一页
table.reload('viewTable', {
  page : {
   curr : currPageNo
  },
  data : tableContent
});

最终效果图:

动态添加一行前(请将图片保存到本地查看大图)

Layui给数据表格动态添加一行并跳转到添加行所在页的方法

动态添加一行后(请将图片保存到本地查看大图)

Layui给数据表格动态添加一行并跳转到添加行所在页的方法

以上这篇Layui给数据表格动态添加一行并跳转到添加行所在页的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery ajax abort()的使用方法
Oct 28 Javascript
JavaScript中变量提升 Hoisting
Jul 03 Javascript
JS操作Cookies包括(读取添加与删除)
Dec 26 Javascript
jQuery 借助插件Lavalamp实现导航条动态美化效果
Sep 27 Javascript
JavaScript运动减速效果实例分析
Aug 04 Javascript
js实现把图片的绝对路径转为base64字符串、blob对象再上传
Dec 29 Javascript
原生js简单实现放大镜特效
May 16 Javascript
详解用node搭建简单的静态资源管理器
Aug 09 Javascript
vue2.0项目实现路由跳转的方法详解
Jun 21 Javascript
解决使用layui的时候form表单中的select等不能渲染的问题
Sep 18 Javascript
jQuery使用hide()、toggle()函数实现相机品牌展示隐藏功能
Jan 29 jQuery
JavaScript的Set数据结构详解
Feb 18 Javascript
微信小程序 MinUI组件库系列之badge徽章组件示例
Aug 20 #Javascript
获取layer.open弹出层的返回值方法
Aug 20 #Javascript
react.js组件实现拖拽复制和可排序的示例代码
Aug 20 #Javascript
layui弹出层按钮提交iframe表单的方法
Aug 20 #Javascript
详解如何在Vue里建立长按指令
Aug 20 #Javascript
微信小程序scroll-view实现滚动穿透和阻止滚动的方法
Aug 20 #Javascript
Angular6 写一个简单的Select组件示例
Aug 20 #Javascript
You might like
php缓冲 output_buffering和ob_start使用介绍
2014/01/30 PHP
PHP判断文章里是否有图片的简单方法
2014/07/26 PHP
yiic命令时提示“php.exe”不是内部或外部命令的解决方法
2014/12/18 PHP
PHP5.5迭代生成器用法实例详解
2016/03/16 PHP
php使用ffmpeg获取视频信息并截图的实现方法
2016/05/03 PHP
php基于dom实现读取图书xml格式数据的方法
2017/02/03 PHP
js实现文本框中焦点在最后位置
2014/03/04 Javascript
javascript类型系统 Window对象学习笔记
2016/01/07 Javascript
JS Attribute属性操作详解
2016/05/19 Javascript
Js调用Java方法并互相传参的简单实例
2016/08/11 Javascript
微信小程序 vidao实现视频播放和弹幕的功能
2016/11/02 Javascript
原生js实现类似fullpage的单页/全屏滚动
2017/01/22 Javascript
用nodeJS搭建本地文件服务器的几种方法小结
2017/03/16 NodeJs
浅谈js的解析顺序 作用域 严格模式
2017/10/23 Javascript
JS中常用的消息框总结
2018/02/24 Javascript
Vue实现一个无限加载列表功能
2018/11/13 Javascript
webpack中如何加载静态文件的方法步骤
2019/05/18 Javascript
vue如何搭建多页面多系统应用
2020/06/17 Javascript
python用来获得图片exif信息的库实例分析
2015/03/16 Python
python3实现ftp服务功能(客户端)
2017/03/24 Python
windows下python安装paramiko模块和pycrypto模块(简单三步)
2017/07/06 Python
关于Python字符串显示u...的解决方式
2020/03/06 Python
django中url映射规则和服务端响应顺序的实现
2020/04/02 Python
Python pysnmp使用方法及代码实例
2020/08/24 Python
实例讲解使用CSS实现多边框和透明边框的方法
2015/09/08 HTML / CSS
抽象类和接口的区别
2012/09/19 面试题
写自荐信要注意什么
2013/12/26 职场文书
三年级语文教学反思
2014/02/01 职场文书
经济信息系毕业生自荐信范文
2014/03/15 职场文书
法律七进实施方案
2014/03/15 职场文书
小学教师培训方案
2014/06/09 职场文书
清明节扫墓活动总结
2015/02/09 职场文书
2015年安全员工作总结范文
2015/04/22 职场文书
浅谈Redis变慢的原因及排查方法
2022/06/21 Redis
redis protocol通信协议及使用详解
2022/07/15 Redis
LyScript实现绕过反调试保护的示例详解
2022/08/14 Python