当前位置: 首页 > news >正文

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

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

http://www.jsqmd.com/news/104268/

相关文章:

  • 2025年重庆三角洲陪玩公司权威推荐榜单:三角洲高KD陪玩/三角洲行动陪玩/三角洲升级陪玩专业服务机构精选 - 品牌推荐官
  • 2025年12月桥梁圆柱模,定制圆柱模,调节式圆柱模厂家品牌推荐榜,彰显国产技术实力 - 品牌鉴赏师
  • Word:出现错误我们无法启动你的程序。请尝试重新启动它
  • 基于java + vue旅游网系统(源码+数据库+文档)
  • 软件测试心得-压测
  • 上海旧房翻新找专业公司!2025年12月权威榜单出炉,十家实力企业上榜 - 速递信息
  • jQuery EasyUI 数据网格 - 添加工具栏
  • 基于springboot + vue酒店预订系统(源码+数据库+文档)
  • EmotiVoice语音合成时间戳功能:精确对齐字幕与音频
  • Shell Sort
  • 羊驼毛制品的优缺点
  • AA精通BTC第3版精读02
  • LobeChat法律咨询原型:专业领域问答系统的构建
  • jQuery EasyUI 数据网格 - 动态改变列
  • 2025上海装潢公司排行:五大靠谱团队推荐与解析,市场装潢门店优质品牌选购指南 - 品牌推荐师
  • 基于springboot + vue律师咨询系统(源码+数据库+文档)
  • jQuery EasyUI 布局 - 创建 XP 风格左侧面板
  • 2025 年 12 月工业自动化设备厂家权威推荐榜:上料机/工业机器人/自动化设备,智能高效与稳定可靠的技术先锋深度解析 - 品牌企业推荐师(官方)
  • 唤醒沉睡脑力,轻松高效记忆
  • AWS数据迁移实战:如何在不中断业务的情况下完成PB级数据迁移
  • Python中同步MySQL驱动对比
  • 基于springboot + vue在线音乐播放系统(源码+数据库+文档)
  • 《管理世界》地级市常态化财会监督改革试点DID2012-2024
  • jQuery EasyUI 数据网格 - 格式化列
  • 提示工程架构师进阶:Agentic AI创新应用的高级案例分析
  • logback日志级别
  • EmotiVoice项目GitHub爆火背后的原因分析
  • jQuery EasyUI 布局 - 创建折叠面板
  • 语音合成个性化推荐系统:基于用户偏好选择音色
  • jQuery EasyUI 布局 - 创建标签页(Tabs)