0

0

如何在 jQuery 日历中动态注入 PHP 生成的事件数据

心靈之曲

心靈之曲

发布时间:2026-03-07 13:13:11

|

853人浏览过

|

来源于php中文网

原创

如何在 jQuery 日历中动态注入 PHP 生成的事件数据

本文详解如何安全、规范地将 PHP 后端获取的多条日历事件数据(如标题、日期等)传递至前端 jQuery 日历插件,并构建符合要求的 events 数组,避免 XSS 风险与日期格式错误。

本文详解如何安全、规范地将 php 后端获取的多条日历事件数据(如标题、日期等)传递至前端 jquery 日历插件,并构建符合要求的 `events` 数组,避免 xss 风险与日期格式错误。

在 Web 开发中,常需将 PHP 动态生成的日历事件(如文章发布日、活动安排等)渲染到前端 jQuery 日历组件中。关键挑战在于:PHP 运行于服务端,jQuery 运行于浏览器端,二者无法直接交互。因此,必须通过“服务端输出 → 客户端可读数据结构”的桥梁方式完成数据传递。以下提供一种安全、可维护、符合现代前端实践的实现方案。

✅ 推荐做法:使用 json_encode() 输出结构化事件数组

直接拼接字符串(如 echo sprintf('<script>let eventStr = ...'))存在严重隐患:易引发 XSS 漏洞、日期/字符串转义失败、中文乱码等问题。正确方式是——<strong>在 PHP 中构造完整事件数组,用 json_encode() 安全序列化为 JSON,再嵌入 <script> 标签中供 JS 消费。</script>

▶ PHP 端:构造并输出 JSON 事件数据

<?php
$events = [];
foreach ($collection as $content) {
    $title = htmlspecialchars($content->getData('title'), ENT_QUOTES, 'UTF-8');
    $ogDate = $content->render('mmedia_library_publish_date', ['type' => 'date_short']);
    $timestamp = strtotime($ogDate);

    // 关键:确保日期格式兼容 JavaScript Date 构造函数(推荐 ISO 8601: "YYYY-MM-DD")
    $isoDate = $timestamp ? date('Y-m-d', $timestamp) : null;

    if ($isoDate) {
        $events[] = [
            'date'        => $isoDate,
            'eventName'   => $title,
            'className'   => 'badge bg-primary', // 可按业务逻辑动态设置
            'dateColor'   => '#2c3e50',
            'customData'  => ['id' => $content->getId()] // 支持扩展字段
        ];
    }
}
?>
<!-- 将 PHP 数组安全转为前端可用的 JS 变量 -->
<script type="application/json" id="calendar-events-data">
<?php echo json_encode($events, JSON_UNESCAPED_UNICODE | JSON_HEX_TAG | JSON_HEX_AMP); ?>
</script>

⚠️ 注意事项:

Runwayml(AI painting)
Runwayml(AI painting)

Runway 平台的文本生成图像AI工具

下载
  • 使用 htmlspecialchars() 对用户输入内容(如 $title)进行 HTML 实体编码,防止 XSS;
  • json_encode() 必须启用 JSON_UNESCAPED_UNICODE,否则中文会转为 \uXXXX 形式;
  • 使用 <script type="application/json"> 而非 text/javascript,语义更清晰且不执行脚本,安全性更高;</script>
  • 日期务必使用 Y-m-d 格式(而非原文中的 Y-d-m),否则 new Date("2022-15-03") 将解析失败。

▶ JavaScript 端:解析 JSON 并初始化日历

<script type="text/javascript">
require([
    'jquery',
    'calendar-gc',
    'domReady!'
], function ($) {
    // 从 script 标签中安全读取预置事件数据
    const eventsDataEl = document.getElementById('calendar-events-data');
    const phpEvents = eventsDataEl ? JSON.parse(eventsDataEl.textContent) : [];

    // 将 PHP 事件转换为 calendarGC 所需格式(注意 Date 对象实例化)
    const calendarEvents = phpEvents.map(item => ({
        date: new Date(item.date), // 自动解析 "YYYY-MM-DD"
        eventName: item.eventName,
        className: item.className,
        dateColor: item.dateColor,
        onclick(e, data) {
            console.log('Event clicked:', { ...item, ...data });
        }
    }));

    // 初始化日历,传入动态生成的 events 数组
    const calendar = $("#calendar").calendarGC({
        dayBegin: 0,
        prevIcon: '<',
        nextIcon: '>',
        onPrevMonth: function (e) { console.log('Prev month:', e); },
        onNextMonth: function (e) { console.log('Next month:', e); },
        events: calendarEvents, // ✅ 此处使用动态数据
        onclickDate: function (e, data) {
            console.log('Date clicked:', e, data);
        }
    });
});
</script>

? 为什么不用 eval() 或内联 echo "<script>var events = [...]"?</script>

  • ❌ eval() 是高危操作,禁止解析不可信 JSON;
  • ❌ 直接 echo "<script>var arr = " . json_encode(...) . "</script>" 若未严格设置 JSON_HEX_* 标志,可能因 字符串导致标签提前闭合,引发解析错误或 XSS;
  • ✅ 使用 <script type="application/json"> + JSON.parse() 是 W3C 推荐的安全模式,完全规避执行风险,且语义明确、调试友好。</script>

? 总结

步骤 关键点
PHP 构造 使用 json_encode() 输出标准 JSON,对敏感字段做 htmlspecialchars() 处理
日期格式 统一为 Y-m-d(ISO 8601),确保 new Date() 正确解析
前端加载 通过 textContent 读取 <script type="application/json"> 内容,再 JSON.parse()</script>
事件映射 在 JS 中将 PHP 数据对象映射为 calendarGC 所需的 date, eventName 等字段
安全底线 永远不拼接 HTML/JS 字符串,不使用 eval(),不信任任何未过滤的用户数据

该方案兼顾安全性、可读性与可扩展性,适用于 Laravel、Magento、WordPress 等各类 PHP 框架环境,是前后端事件数据协同的稳健实践。

立即学习PHP免费学习笔记(深入)”;

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

339

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

291

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

728

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

135

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

76

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

159

2026.03.04

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

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

1

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号