news 2026/6/15 6:50:50

jQuery EasyUI 数据网格 - 添加查询(搜索)功能

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery EasyUI 数据网格 - 添加查询(搜索)功能

jQuery EasyUI 数据网格 - 添加查询(搜索)功能

datagrid添加查询功能是实际应用中最常见的需求之一。EasyUI 官方没有内置统一的搜索框,但可以通过以下几种方式轻松实现:

  1. 工具栏(toolbar)搜索框 + 手动查询(最常用、灵活)
  2. 内置搜索框扩展(使用 datagrid 的 load 参数过滤)

本教程重点介绍第一种方式:在工具栏添加搜索框和按钮,点击“查询”后向服务器传递参数重新加载数据。

官方参考:

  • 带搜索的 DataGrid 示例:https://www.jeasyui.com/tutorial/datagrid/datagrid23.php
  • 在线 Demo:https://www.jeasyui.com/demo/main/index.php?plugin=DataGrid&pitem=Client+Pagination
步骤 1: 创建带工具栏的 DataGrid
<tableid="dg"class="easyui-datagrid"title="用户管理"style="width:800px;height:500px"data-options="url:'get_users.php',fitColumns:true,pagination:true,rownumbers:true,pageSize:10"><thead><tr><thfield="id"width="80"sortable="true">ID</th><thfield="username"width="100">用户名</th><thfield="name"width="100">姓名</th><thfield="email"width="180">邮箱</th><thfield="phone"width="120">电话</th><thfield="regdate"width="100"sortable="true">注册日期</th></tr></thead></table><!-- 工具栏 --><divid="toolbar"><divstyle="padding:5px;">用户名:<inputid="search_username"class="easyui-textbox"style="width:150px;">姓名:<inputid="search_name"class="easyui-textbox"style="width:150px;">注册日期从:<inputid="search_startdate"class="easyui-datebox"style="width:120px;">到:<inputid="search_enddate"class="easyui-datebox"style="width:120px;"><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-search"onclick="doSearch()">查询</a><ahref="javascript:void(0)"class="easyui-linkbutton"iconCls="icon-reload"onclick="clearSearch()">重置</a></div></div>
步骤 2: 配置工具栏和 JavaScript 查询逻辑
<scripttype="text/javascript">$(function(){$('#dg').datagrid({toolbar:'#toolbar',// 指定工具栏singleSelect:true});});// 执行查询functiondoSearch(){$('#dg').datagrid('load',{username:$('#search_username').val(),name:$('#search_name').val(),startdate:$('#search_startdate').datebox('getValue'),// YYYY-MM-DD 格式enddate:$('#search_enddate').datebox('getValue')});}// 重置搜索条件functionclearSearch(){$('#search_username').textbox('clear');$('#search_name').textbox('clear');$('#search_startdate').datebox('clear');$('#search_enddate').datebox('clear');// 重新加载原始数据(无参数)$('#dg').datagrid('load',{});}</script>
步骤 3: 后端 PHP 示例(get_users.php)

服务器端接收参数并在 SQL 中使用(注意防注入):

<?php// get_users.php$page=isset($_POST['page'])?intval($_POST['page']):1;$rows=isset($_POST['rows'])?intval($_POST['rows']):10;$offset=($page-1)*$rows;$where=" WHERE 1=1 ";$params=[];// 查询条件if(!empty($_POST['username'])){$where.=" AND username LIKE ?";$params[]='%'.$_POST['username'].'%';}if(!empty($_POST['name'])){$where.=" AND name LIKE ?";$params[]='%'.$_POST['name'].'%';}if(!empty($_POST['startdate'])){$where.=" AND regdate >= ?";$params[]=$_POST['startdate'];}if(!empty($_POST['enddate'])){$where.=" AND regdate <= ?";$params[]=$_POST['enddate'];}// 查询总数$count_sql="SELECT COUNT(*) AS total FROM users".$where;$stmt=$pdo->prepare($count_sql);$stmt->execute($params);$total=$stmt->fetch()['total'];// 查询数据$sql="SELECT * FROM users".$where." ORDER BY id DESC LIMIT$offset,$rows";$stmt=$pdo->prepare($sql);$stmt->execute($params);$items=$stmt->fetchAll(PDO::FETCH_ASSOC);echojson_encode(['total'=>$total,'rows'=>$items]);?>
完整效果
  • 用户在工具栏输入条件 → 点击“查询” → datagrid 自动向get_users.php传递参数 → 服务器返回过滤后的数据 + 分页 → 表格刷新显示结果。
  • 点击“重置” → 清空条件并重新加载所有数据。
扩展功能
  1. 回车键查询
$('#search_username,#search_name').textbox({inputEvents:$.extend({},$.fn.textbox.defaults.inputEvents,{keyup:function(e){if(e.keyCode==13){doSearch();}}})});
  1. 高级搜索面板(可折叠):
    将搜索条件放入一个 panel 或 dialog,点击“高级搜索”展开。

  2. 客户端分页搜索(数据量小):
    使用clientPagination: true+ 本地数据,搜索时过滤 rows。

更多示例
  • 官方搜索示例:https://www.jeasyui.com/tutorial/datagrid/datagrid23.php
  • 复杂查询表单:https://www.jeasyui.com/demo/main/index.php?plugin=DataGrid&pitem=SearchBox

如果需要高级搜索弹窗模糊搜索自动完成导出带查询条件的数据或其他高级查询功能,请继续提问!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 9:31:41

jQuery EasyUI 数据网格 - 创建复杂工具栏

jQuery EasyUI 数据网格 - 创建复杂工具栏 datagrid 的工具栏&#xff08;toolbar&#xff09;支持非常灵活的布局&#xff0c;可以创建包含多行按钮、分隔线、下拉菜单、搜索框、分页自定义、状态显示等的复杂工具栏。这在实际后台管理系统中非常常见&#xff0c;能让操作区更…

作者头像 李华
网站建设 2026/6/15 5:39:15

jQuery EasyUI 数据网格 - 设置冻结列

jQuery EasyUI 数据网格 - 设置冻结列&#xff08;Frozen Columns&#xff09; 冻结列&#xff08;Frozen Columns&#xff09;是 datagrid 的重要功能&#xff0c;它允许将左侧的部分列“冻结”&#xff0c;在水平滚动表格时这些列始终固定显示&#xff0c;不随内容滚动。非常…

作者头像 李华
网站建设 2026/6/15 11:24:45

唤醒沉睡脑力,轻松高效记忆

你是否曾羡慕过那些记忆力超群的人&#xff1f;他们看一本书似乎只需翻几页&#xff0c;学习新知识像喝水一样轻松&#xff0c;而你却总在遗忘中挣扎&#xff1f;别急着归咎于天赋&#xff0c;科学告诉我们&#xff0c;大脑的潜能远比想象中更强大。三易脑科学&#xff08;深圳…

作者头像 李华
网站建设 2026/6/15 12:17:19

基于springboot + vue在线音乐播放系统(源码+数据库+文档)

在线音乐播放系统 目录 基于springboot vue超在线音乐播放系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 基于springboot vue超在线音乐播放系统 一、前言 博主介…

作者头像 李华
网站建设 2026/6/15 10:25:48

2026毕设ssm+vue基于框架的旅游订票系统论文+程序

本系统&#xff08;程序源码&#xff09;带文档lw万字以上 文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容一、选题背景&#xff08;≈300 字&#xff09; 关于“动漫&#xff0b;旅游”融合型线上平台的研究&#xff0c;现有成果主要以宏观产业分…

作者头像 李华
网站建设 2026/6/15 10:24:58

EmotiVoice语音缓存机制设计:提升重复内容播放效率

EmotiVoice语音缓存机制设计&#xff1a;提升重复内容播放效率 在如今的AI语音应用中&#xff0c;用户常常会反复听到相同的提示语——“电量不足&#xff0c;请及时充电”、“您有新的消息”或者游戏里NPC那句熟悉的“欢迎光临”。如果每次都需要重新跑一遍完整的神经网络推理…

作者头像 李华