0

0

如何通过不同链接动态加载不同查询结果到同一模态框中

聖光之護

聖光之護

发布时间:2026-01-20 17:10:05

|

534人浏览过

|

来源于php中文网

原创

如何通过不同链接动态加载不同查询结果到同一模态框中

本文介绍在 php + bootstrap 环境下,如何让多个 `` 标签触发同一个模态框(modal),但根据点击来源动态加载对应 sql 查询结果,避免重复定义多个模态框或硬编码逻辑。

要实现“单个模态框、多数据源”的效果,核心在于解耦 HTML 渲染与数据获取逻辑:原始代码中所有查询($tekmuhadiTab 和 $tekmuhadiTab2)在页面加载时即执行,并在模态框 HTML 中静态输出(while(odbc_fetch_row(...))),这导致无法按需切换数据源。

✅ 正确做法是采用 AJAX 驱动的动态内容加载——点击链接时不直接打开含死数据的模态框,而是先发送请求获取对应查询结果,再注入到模态框中并显示。

Napkin AI
Napkin AI

Napkin AI 可以将您的文本转换为图表、流程图、信息图、思维导图视觉效果,以便快速有效地分享您的想法。

下载

✅ 推荐方案:AJAX + Bootstrap Modal(服务端 PHP + 前端 JS)

1. 修改 HTML 链接,携带查询标识

<a href="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b" data-query="tekmuhadi" data-toggle="modal" data-target="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bmyModal" 
   class="modalaltfiltre fas fa-search text-sm opacity-10">查表1</a>

<a href="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b" data-query="tekmuhadi2" data-toggle="modal" data-target="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bmyModal" 
   class="modalaltfiltre fas fa-search text-sm opacity-10">查表2</a>

2. 保留单一模态框结构(移除 PHP 循环)

<div class="modal fade" id="myModal" tabindex="-1" role="dialog">
  <div class="modal-dialog">
    <div class="modal-content">
      <div class="modal-header">
        <h5 class="modal-title" id="modalTitle">加载中...</h5>
        <button type="button" class="close" data-dismiss="modal">&times;</button>
      </div>
      <div class="modal-body">
        <div id="modalContent">
          <div class="text-center"><span class="spinner-border spinner-border-sm"></span> 正在加载...</div>
        </div>
      </div>
    </div>
  </div>
</div>

3. 添加 JavaScript 监听与异步加载逻辑

<script>
$('https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bmyModal').on('show.bs.modal', function (event) {
  const button = $(event.relatedTarget); // 触发按钮
  const queryType = button.data('query'); // 如 'tekmuhadi'
  const modal = $(this);

  // 设置标题(可选)
  modal.find('.modal-title').text(
    queryType === 'tekmuhadi' ? '技术部门人员列表' : '技术部门备选名单'
  );

  // AJAX 加载对应数据
  $.get('fetch_data.php', { query: queryType }, function (data) {
    modal.find('https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bmodalContent').html(data);
  }).fail(function () {
    modal.find('https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15bmodalContent').html('<div class="alert alert-danger">数据加载失败,请重试。</div>');
  });
});
</script>

4. 创建 fetch_data.php 统一处理查询(安全+可扩展)

<?php
// fetch_data.php —— 使用 PDO 或 ODBC 安全执行查询
$conn = odbc_connect(/* your DSN */);

// 白名单校验,防止参数注入
$allowedQueries = ['tekmuhadi', 'tekmuhadi2'];
$queryKey = $_GET['query'] ?? '';
if (!in_array($queryKey, $allowedQueries)) {
    http_response_code(400);
    echo '<div class="alert alert-warning">无效的数据请求。</div>';
    exit;
}

// 定义查询语句(建议移至配置或 switch)
$sqlMap = [
    'tekmuhadi'  => "SELECT name, dept, phone FROM tech_staff",
    'tekmuhadi2' => "SELECT name, status, last_updated FROM tech_backup"
];

$result = odbc_exec($conn, $sqlMap[$queryKey]);
if (!$result) {
    echo '<div class="alert alert-danger">查询执行失败。</div>';
    exit;
}

// 渲染表格(注意:odbc_result 字段索引从 1 开始)
echo '<table class="table table-sm mb-0">';
echo '<thead><tr><th>姓名</th><th>部门/状态</th><th>联系方式/更新时间</th></tr></thead><tbody>';

while (odbc_fetch_row($result)) {
    echo '<tr>';
    echo '<td>' . htmlspecialchars(odbc_result($result, 1)) . '</td>';
    echo '<td>' . htmlspecialchars(odbc_result($result, 2)) . '</td>';
    echo '<td>' . htmlspecialchars(odbc_result($result, 3)) . '</td>';
    echo '</tr>';
}
echo '</tbody></table>';
?>

⚠️ 注意事项

  • 绝不暴露原始 SQL 或变量名到前端:使用白名单(如 $allowedQueries)严格限制可执行查询类型;
  • 始终转义输出内容:用 htmlspecialchars() 防止 XSS;
  • ODBC 字段索引从 1 开始,且需确保字段数一致,否则 odbc_result($r,3) 可能报错;
  • 若需分页/搜索等高级功能,应在 fetch_data.php 中支持 GET 参数(如 ?query=tekmuhadi&page=2);
  • 替代方案(不推荐):服务端预执行全部查询并缓存结果,通过 data-* 属性传入 JSON 数据——仅适用于极小数据集,存在内存与安全风险。

通过该架构,你只需维护一个模态框、一个后端接口和清晰的查询映射,即可灵活支持任意数量的数据源,真正实现「一次定义、按需渲染」。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1110

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

380

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2069

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

379

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1602

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

439

2024.04.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号