当前位置: 首页 > 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.zskr.cn/news/115092.html

相关文章:

  • Word:出现错误我们无法启动你的程序。请尝试重新启动它
  • 基于java + vue旅游网系统(源码+数据库+文档)
  • jQuery EasyUI 数据网格 - 添加工具栏
  • Shell Sort
  • EmotiVoice语音合成时间戳功能:精确对齐字幕与音频
  • 2025上海装潢公司排行:五大靠谱团队推荐与解析,市场装潢门店优质品牌选购指南 - 品牌推荐师
  • AWS数据迁移实战:如何在不中断业务的情况下完成PB级数据迁移
  • Python中同步MySQL驱动对比
  • 《管理世界》地级市常态化财会监督改革试点DID2012-2024
  • logback日志级别
  • Cursor Rule:AI如何革新代码导航与智能提示
  • AI应用架构师干货:GNN在医疗病历分析中的架构设计
  • MySQL变长字段的庖丁解牛
  • xcchat 是一个基于 Django 和 Django Channels 构建的轻量级在线客服系统。它支持实时聊天、人工/机器人客服切换、访客信息追踪和多站点接入
  • 【大模型微调】11-Prefix Tuning技术:分析Prefix Tuning的工作机制
  • 揭秘大数据领域规范性分析的关键流程
  • 文件上传漏洞检测工具对比:传统VS AI驱动
  • 告别手动测试:MQTT自动化测试脚本开发全攻略
  • 【大模型微调】10-BitFit技术:介绍BitFit的原理及其在微调中的应用
  • EmotiVoice语音合成系统灰度发布AB测试设计模板
  • EmotiVoice语音合成离线运行能力:无网络环境下正常使用
  • windows配置wsl网络代理
  • 3个Budibase企业级应用案例解析
  • 企业级实战:CentOS7+Nginx高可用集群部署指南
  • if you are using weblogic you will need to add ‘org.slf4j‘ to prefer-applica开发效率提升秘籍
  • 新手必看:用AI助手轻松学会J-Flash烧录
  • 2025年网带烘干设备批发厂家权威推荐榜单:网带干燥设备/网带烘干机/带式烘干机源头厂家精选 - 品牌推荐官
  • 【JavaWeb】路径问题_响应重定向和请求转发的路径问题
  • 零基础学Java:从安装到第一个程序的完整指南
  • 用海拥技术1小时打造可运行的产品原型