EasyUI表格增加筛选和导出的方法

news2024/11/15 11:12:48

一、前言

最近写前端页面,要从后台查询表格数据;

查到数据后,就想增加个数据筛选功能,如果再查后台的话会影响效率(还得加参数、再调用后台接口、后台再执行sql),就想前端能不能自己筛选下已经获得的数据,不要再调用后台接口。

同时,还想增加个导出excel功能,也是想前端能不能自己导出、不要再调用后台接口。

二、实现方法简述

1.前端项目是EasyUI的,前后端未分离;
2.使用EasyUI的datagrid-export.jsdatagrid-filter.js就可以快速实现。
官方文档地址:

http://www.jeasyui.com/extension/datagrid_export.php
http://www.jeasyui.com/extension/datagrid_filter.php

3.最终实现效果
在这里插入图片描述

三、实现方法详细步骤

1.EasyUI的前端项目可用。

2.打开官网连接,下载datagrid_exportdatagrid_filter的压缩包(官网最下方有下载按钮),找到datagrid-export.jsdatagrid-filter.js这2个文件,放到自己的项目里。
在这里插入图片描述

3.datagrid-filter.js就是表格筛选用的,使用后表格第一行就会变成筛选行;
本人用的没有设置样式,也可以看官方文档、设置成下拉菜单等样式。
代码比较简单,主要如下:

//注意路径src,看放在项目的哪里了,根据实际情况填写
<script type="text/javascript" src="datagrid-filter.js"></script>
//这个是表格,id是myDataTable
	<div data-options="region:'center',border:false" style="overflow: hidden;">
		<table id="myDataTable">
		</table>
	</div>

//启用表格筛选功能,这个myDataTable是表格ID,enableFilter是固定参数
$('#myDataTable').datagrid('enableFilter');

这样,就可以实现表格筛选功能。

4.datagrid-export.js就是表格导出用的,官网有详细说明。
本人只用到了导出excel,所以也是最简单的写法:

//注意路径src,看放在项目的哪里了,根据实际情况填写
<script type="text/javascript" src="datagrid-export.js"></script>
//这个是表格,id是myDataTable
	<div data-options="region:'center',border:false" style="overflow: hidden;">
		<table id="myDataTable">
		</table>
	</div>

//导出方法,找个按钮调用这个方法即可	
		function exportMyTable() {
            $('#myDataTable').datagrid('toExcel','导出表格名称.xls');
		}

四、备注

EasyUI的表格数据查询后台接口的写法:

		jQuery(function() {
			//初始化列表
			$('#myDataTable').datagrid({
                iconCls : 'icon-tip',
                //这个接口是后台接口,返回的数据是固定格式的,这样框架就能解析 
                // {"total":10,"rows"[{"id":"1","name":"a"},{"id":"2","name":"b"}]}
                url :  'http://localhost:8080/mytest/tableData', 
                singleSelect : false,
                rownumbers : true,
                pagination : true,//是否显示分页
                pageSize : 10, //每页大小
                //pageList : [ 25, 50, 75, 100 ], //页大小下拉选项,此项各value是pageSize的倍数
                fit : true,//自适应宽度
                fitColumns : false,
                method : 'post',
                nowap : false, //列内容多时自动折至第二行
                striped : true, //行背景交换
                idField : 'id',//此处根据实际情况进行填写,是返回的rows里的每个元素的id
                columns : [ [ {
                    field : 'id',
                    title : 'ID',
                    width : 100
                }, {
                    field : 'name',
                    title : '姓名',
                    align : 'center',
                    width : 70
                }
                    //注:最后一行后面的逗号要去掉
                ] ],
				toolbar : [ {
                    id : 'btnexport',
                    text : '导出',
                    iconCls : 'icon-export',
                    handler : function() {
                        //这个就是上面截图的导出按钮
                        exportMyTable();
                    }
                } ],
                onBeforeLoad : function () {//加载之前,不允许点导出按钮
                    $('#btnexport').linkbutton('disable');
                },
                onLoadSuccess : function(data) {
                    //如果总数据为0条,将当前page设置为第1页
                    if(data.total==0){
                        $(this).datagrid('options').pageNumber=1
                    }
                    if (data.rows.length > 0){
                        $('#btnexport').linkbutton('enable');
                    } else if(data.rows.length == 0) {
                        $('#btnexport').linkbutton('disable');
                    }
                    //这句可以清空datagrid之前的选择状态,防止后续逻辑出错
                    $('#myDataTable').datagrid('clearSelections'); 
                    //启用表格筛选功能
					$('#myDataTable').datagrid('enableFilter');

                }
			});
		});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/672240.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

车载以太网 - 传输层 - TCP通信过程

目录 TCP 通信阶段 1、连接建立Connection establishment 2、数据传输 Data transfer 3、连接释放 Connection release TCP通信的三个阶段: TCP连接&#xff08;三次握手&#xff09; 1、Client(ECUA) -> Server(ECU B)第一次握手 2、Server -> Client 第二次握手…

软件工程基础速通教程(北京理工大学)

文章目录 前言软工上课情况考后感题型分析概念部分大题部分数据流图和数据字典数据流图数据字典 结构化设计工具程序流程图盒图&#xff08;N-S图&#xff09;PAD图判定表和判定树PDL&#xff08;伪码&#xff09; 软件测试白盒测试法语句覆盖判定覆盖&#xff0c;条件覆盖&…

【MMDetection3.0】训练自己的数据集

本文记录下MMDetection3.0版本&#xff0c;即截至目前最新的版本&#xff0c;训练自定义数据集的过程。当前MMDetection已经封装的很好了&#xff0c;虽然易于使用&#xff0c;但其API也愈发复杂&#xff0c;对于新手不太友好&#xff0c;这里记录下自己的踩坑经历。 数据部分…

5.英语词性之副词

五.什么是副词 副词是修饰动词&#xff0c;形容词&#xff0c;副词的词语&#xff0c;有时也可以修饰数词&#xff0c;介词&#xff0c;连词&#xff0c;名词或全 句。副词是表示行为或状态特征的词&#xff0c;主要作状语&#xff0c;也可以作表语&#xff0c;定语&#xff0c…

音视频开发:Qt在视频剪辑3D桌面软件获胜, 嵌入式不敌安卓

1 Qt Android嵌入式应用层开发方向对比 大家都知道啊&#xff0c;做嵌入式linux设备&#xff0c;一些没有屏幕&#xff0c;比如安防摄像头&#xff0c;门铃之类的&#xff0c;另外一些嵌入式设备是有触控屏&#xff0c;在触控屏上还跑应用软件的&#xff0c;这种比如商场各种…

citywalk话题增长704.76%,小红书本地化内容营销怎么玩?

2023年初发布的《2023小红书年度生活趋势&#xff1a;投入真实生活》报告中提到&#xff0c;今后年轻人会更加意识到周围和附近的重要性&#xff0c;在十大生活趋势预测中&#xff0c;近邻升温&#xff08;2022年相关笔记数量同比上涨213%&#xff09;、野到家门口&#xff08;…

建立小型医学数据库(总结)

建立小型医学数据库 小型医学数据库可以用于存储和管理医学数据&#xff0c;如患者病历、药品信息、试验结果等。这对于医疗机构和科研机构来说非常必要&#xff0c;可以提高数据管理和共享的效率&#xff0c;进而促进医学研究和诊疗水平的提升。 建立小型医学数据库有以下基本…

转发和重定向的区别及其原理

在web应用中完成资源的跳转 在一个web应用中完成资源的跳转可以通过转发或者重定向两种方式, 跳转的资源只要是服务器内部合法的资源即可(如Servlet、JSP、HTML…) 转发机制使用场景: 某个Servlet向request域当中绑定了数据&#xff0c;希望从其他Servlet当中把request域里面…

【Python】Django 基础知识

系列文章目录 提示&#xff1a;阅读本章之前&#xff0c;请先阅读目录 文章目录 系列文章目录前言安装启动项目查看所有子命令主要文件setting 配置项URL 请求路径path 转换器HttpResponse 输出中文乱码models的objects代码自动补全views的request 代码自动补全views的request.…

沃尔玛、亚马逊跨境电商如何实现自养账号采退、海淘及测评的

今天曹哥还是针对下亚马逊、沃尔玛跨境平台如何实现自己养买家号可以给自己采购、海淘及测评等技术问题 首先你要有一个稳定的环境方案&#xff0c;这个是做自养号采购、海淘及测评的基础。环境有很多&#xff0c;从早期的虚拟机&#xff0c;模拟机&#xff0c;云手机&#xf…

[进阶]Java:IO流分类、文件字节输入流、读取字节数据、避免乱码问题

IO流概述 I表示intput&#xff0c;是数据从硬盘文件读入到内存的过程&#xff0c;称之输入&#xff0c;负责读。O表示output&#xff0c;是内存程序的数据从内存到写出到硬盘文件的过程&#xff0c;称之输出&#xff0c;负责写。 IO流的分类 按流的方向分 按流中的数据最小单…

树状数组(入门附模板)

声明&#xff1a;本篇文章图片非原创 目录 简介 lowbit函数 结构分析 单点修改,区间查询 区间修改,单点查询 区间修改,区间查询 模板题 树状数组1–单点修改,区间查询 题目描述 输入格式 输出格式 输入输出样例 输入 #1 输出 #1 说明/提示 分析 代码 树状数…

移动机器人路径优化:基于Q-learning算法的移动机器人路径优化(提供MATLAB代码)

一、Q-learning算法 Q-learning算法是强化学习算法中的一种&#xff0c;该算法主要包含&#xff1a;Agent、状态、动作、环境、回报和惩罚。Q-learning算法通过机器人与环境不断地交换信息&#xff0c;来实现自我学习。Q-learning算法中的Q表是机器人与环境交互后的结果&#…

哈工大计算机网络课程网络层协议详解之:CIDR与路由聚集

哈工大计算机网络课程网络层协议详解之&#xff1a;CIDR与路由聚集 文章目录 哈工大计算机网络课程网络层协议详解之&#xff1a;CIDR与路由聚集CIDR与路由聚集CIDR路由聚集 CIDR与路由聚集 CIDR CIDR&#xff1a;无类域间路由&#xff08;CIDR&#xff1a;Classless InterDo…

2.4C++派生类的函数

C 派生类的构造函数 在C中派生类的构造函数&#xff0c;必须调用基类的构造函数&#xff0c;来初始化从基类继承的数据成员。 具体有两种形式&#xff1a; 1、默认构造函数 2、带参数的构造函数 上面的我写的代码中&#xff0c;DerivedClass 构造函数的初始化列表中调用了 …

前缀和以及map混用,打开思路

补一个坑 目录 以力扣560为例&#xff1a; 力扣1248&#xff0c;优美子数组 力扣974 和可被 K 整除的子数组 力扣523.连续的子数组和 浅谈一下前缀和&#xff1a; 我们通过前缀和数组保存前 n 位的和&#xff0c;presum[1]保存的就是 nums 数组中前 1 位的和&#xff0c;也…

王道考研数据结构--3.双链表

目录 1.前言 2.代码难点 2.1双链表的插入和删除 3.代码函数 3.1双链表结构体定义 3.2双链表初始化函数 3.3双链表插入 3.4双链表节点删除 3.5双链表的遍历 4.全部代码 1.前言 日期&#xff1a;2023.6.21 书籍&#xff1a;2024年数据结构考研复习指导&#xff08;王道…

【计算机视觉】CVPR 23 | 视觉 Transformer 全新学习范式!用长尾数据提升ViT性能

文章目录 一、导读二、介绍三、方法四、总结 一、导读 论文地址&#xff1a; https://arxiv.org/abs/2212.02015代码链接&#xff1a; https://github.com/XuZhengzhuo/LiVT二、介绍 在机器学习领域中&#xff0c;学习不平衡的标注数据一直是一个常见而具有挑战性的任务。近…

JDK自带的构建线程池的方式之newScheduleThreadPool

顾名思义newScheduleThreadPool是一个定时任务的线程池&#xff0c;这个线程池可以定时一定周期去执行任务&#xff0c;也可以实现延迟多久去执行任务一次。 newScheduleThreadPool方法实现展示 基于查看这个方法不难发现&#xff0c;该方法是基于ScheduledThreadPoolExecutor…

基于 Flink CDC 构建 MySQL 到 Databend 的 实时数据同步

这篇教程将展示如何基于 Flink CDC 快速构建 MySQL 到 Databend 的实时数据同步。本教程的演示都将在 Flink SQL CLI 中进行&#xff0c;只涉及 SQL&#xff0c;无需一行 Java/Scala 代码&#xff0c;也无需安装 IDE。 假设我们有电子商务业务&#xff0c;商品的数据存储在 My…