Layui 表格组件 头部工具栏 筛选列 加入全选和全不选的功能

本文主要是介绍Layui 表格组件 头部工具栏 筛选列 加入全选和全不选的功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Layui 表格组件 头部工具栏 筛选列 加入全选和全不选的功能

问题

前端使用Layui表格组件展示后台数据,因数据中涉及字段较多,因此加入了组件中固有的控制表格列隐藏显示的功能。奈何客户希望再此基础上,加入“全选”和“全不选”的功能,更方便的选择想要单独显示的列名。不废话,上图。

表格组件中原始筛选列的效果
上图为:表格组件中原始筛选列的效果

加入全选和全不选后的效果
上图为:加入全选和全不选控制表格列显示的效果

解决过程

编写控制列全选和全不选的代码

var tbLay = {//筛选列加入全选和全不选的功能tableExtendColumnFilter:function(tbId){var $tbView = null;$(".layui-table-view").each(function(index,item){if($(item).attr("lay-id") == tbId){$tbView = $(this);return;}});//.layui-table-tool-panelvar $iconCols = $tbView.find(".layui-icon-cols");$iconCols.click(function(){var selected = `<div class="tb-col-selected-yes-no" style="position: absolute;right: 15px;top: 35px;z-index: 999;width: 120px;"><button type="button" class="layui-btn layui-btn-sm" οnclick="tbLay.tableExtendColumnFilterShow(this,true)">全选</button><button type="button" class="layui-btn layui-btn-sm" οnclick="tbLay.tableExtendColumnFilterShow(this,false)">全不选</button></div>`;if($(this).prev().attr("class") == "tb-col-selected-yes-no"){$(".tb-col-selected-yes-no").show();return;}$(this).before(selected);});},//筛选列全选和全不选点击事件tableExtendColumnFilterShow:function(thisDom,isAllChecked){var liArr = $(thisDom).parent().siblings(".layui-table-tool-panel").find("li");console.log(liArr);liArr.each(function(index,item){var $itemDiv = $(item).find("div");var checked = $itemDiv.hasClass("layui-form-checked"); //原始状态if((isAllChecked && !checked) || (!isAllChecked && checked)){ //全选 || 全不选$itemDiv.click();}});}
}

将上述代码放入tbLayUtil.js

编写控制全选和全不选按钮消失的代码

$(function(){//点击空白处,隐藏筛选列全选和全不选$(document).click(function(e){if(!$(e.target).is(".layui-inline")){$(".tb-col-selected-yes-no").hide();}});
})

将上述代码放入tbLayUtil.js

引入并调用控制列全选和全不选的方法

table.render({elem: '#tb',cols: column,method: "post",headers: {token: $.cookie('token')},url: app.url + "case/yxk/listYxk.do",where: param,parseData: function(res) { //res 即为原始返回的数据return {"code": res.code, //解析接口状态"msg": res.msg, //解析提示文本"count": res.data.count, //解析数据长度"data": res.data.data //解析数据列表};},response: {statusCode: 200 //规定成功的状态码,默认:0},toolbar: true,defaultToolbar: ['filter',{title: '导出', //标题layEvent: 'LAYTABLE_DOWN', //事件名,用于 toolbar 事件中使用icon: 'layui-icon-download-circle' //图标类名}],page: true,autoSort: false, //禁用前段排序height: 'full-60', //高度最大化减去差值width: 'full',done: function(res, curr, count) {//控制列全选和全不选,此处为关键代码tbLay.tableExtendColumnFilter('tb');layer.closeAll('loading'); //关闭加载层}});

将tbLayUtil.js引入表格页面

查看效果即可

这篇关于Layui 表格组件 头部工具栏 筛选列 加入全选和全不选的功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/679826

相关文章

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

SpringKafka消息发布之KafkaTemplate与事务支持功能

《SpringKafka消息发布之KafkaTemplate与事务支持功能》通过本文介绍的基本用法、序列化选项、事务支持、错误处理和性能优化技术,开发者可以构建高效可靠的Kafka消息发布系统,事务支... 目录引言一、KafkaTemplate基础二、消息序列化三、事务支持机制四、错误处理与重试五、性能优

SpringIntegration消息路由之Router的条件路由与过滤功能

《SpringIntegration消息路由之Router的条件路由与过滤功能》本文详细介绍了Router的基础概念、条件路由实现、基于消息头的路由、动态路由与路由表、消息过滤与选择性路由以及错误处理... 目录引言一、Router基础概念二、条件路由实现三、基于消息头的路由四、动态路由与路由表五、消息过滤

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

基于SpringBoot实现文件秒传功能

《基于SpringBoot实现文件秒传功能》在开发Web应用时,文件上传是一个常见需求,然而,当用户需要上传大文件或相同文件多次时,会造成带宽浪费和服务器存储冗余,此时可以使用文件秒传技术通过识别重复... 目录前言文件秒传原理代码实现1. 创建项目基础结构2. 创建上传存储代码3. 创建Result类4.

Python+PyQt5实现多屏幕协同播放功能

《Python+PyQt5实现多屏幕协同播放功能》在现代会议展示、数字广告、展览展示等场景中,多屏幕协同播放已成为刚需,下面我们就来看看如何利用Python和PyQt5开发一套功能强大的跨屏播控系统吧... 目录一、项目概述:突破传统播放限制二、核心技术解析2.1 多屏管理机制2.2 播放引擎设计2.3 专

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

使用PyTorch实现手写数字识别功能

《使用PyTorch实现手写数字识别功能》在人工智能的世界里,计算机视觉是最具魅力的领域之一,通过PyTorch这一强大的深度学习框架,我们将在经典的MNIST数据集上,见证一个神经网络从零开始学会识... 目录当计算机学会“看”数字搭建开发环境MNIST数据集解析1. 认识手写数字数据库2. 数据预处理的