实时获取数据库新增商品的技巧
时间:2026-02-15 15:42:47 361浏览 收藏
本文深入讲解了如何在不刷新页面的情况下实现商品列表的实时动态更新,通过前端AJAX轮询结合后端增量查询(基于最后ID追踪),避免全量重载导致的页面闪烁、性能损耗和事件丢失问题;文中提供了可直接落地的前后端完整代码示例(含健壮的错误处理与优化建议),帮助开发者轻松构建流畅、专业的“实时上新”体验,尤其适用于电商、内容聚合等对数据时效性要求较高的Web应用场景。

本文介绍如何在不刷新页面的前提下,动态加载数据库中新增的商品数据,通过 AJAX 轮询 + 后端增量查询实现高效、无闪烁的实时更新。
本文介绍如何在不刷新页面的前提下,动态加载数据库中新增的商品数据,通过 AJAX 轮询 + 后端增量查询实现高效、无闪烁的实时更新。
在电商类或商品展示型 Web 应用中,用户期望看到“实时上新”——即后台添加新商品后,前端列表能自动呈现,无需手动刷新。直接使用 setInterval 配合 .load() 全量重载(如 $('#players').load(...))不仅性能差、易造成闪烁与重复渲染,还可能因 DOM 结构不一致导致 JS 事件丢失或样式错乱。
更优解是采用增量式轮询(Polling with Last ID Tracking):前端记录已加载商品的最大 ID,每次请求仅拉取该 ID 之后的新商品 HTML 片段,并追加到现有列表末尾。
✅ 正确实现步骤
1. 前端:轮询 + 增量请求
<!-- 确保容器 ID 准确(原代码中为 'parnet',但 JS 写成 'parent',需统一) -->
<div id="store-container" class="row">
<div id="players" class="col-12">
<!-- 初始 PHP 渲染的商品列表 -->
<?php foreach ($players as $player): ?>
<div class="col-lg-6 col-xl-3 mb-4">
<div class="card text-center">
<div class="card-body">
<!-- 商品结构保持不变 -->
<div class="row m-b-30">
<div class="col-md-5 col-xxl-6">
<div class="new-arrival-product mb-4 mb-xxl-4 mb-md-0">
<div class="new-arrivals-img-contnent">
<img class="img-fluid"
src="<?= baseUrl() ?>/upload/images/players/<?= htmlspecialchars($player['image']) ?>"
alt="<?= htmlspecialchars($player['playerName']) ?>">
</div>
</div>
</div>
<div class="col-md-7 col-xxl-6">
<div class="new-arrival-content position-relative">
<h4><?= htmlspecialchars($player['playerName']) ?></h4>
<p>Buy Now Price <span class="item text-success"><?= htmlspecialchars($player['buyPrice']) ?></span></p>
<p>Market Price: <span class="item text-success"><?= htmlspecialchars($player['marketPrice']) ?></span></p>
<p>Price In Dollar: <span class="item text-success"><?= htmlspecialchars($player['price']) ?></span></p>
</div>
<button type="button" class="btn btn-rounded btn-primary btn-sm">
<span class="btn-icon-left text-primary"><i class="fa fa-shopping-cart"></i></span>Buy
</button>
</div>
</div>
</div>
</div>
</div>
<?php endforeach; ?>
</div>
</div>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function () {
// 初始化 lastId:取当前列表最后一个商品的 data-id 属性(需后端在 PHP 中注入)
let lastId = <?= !empty($players) ? (int)$players[count($players)-1]['id'] : 0 ?>;
function fetchNewProducts() {
$.get('/api/get-new-players.php', { last_id: lastId })
.done(function (response) {
try {
const data = JSON.parse(response);
if (!data.error && Array.isArray(data.items) && data.items.length > 0) {
// 更新 lastId 为最新商品 ID
lastId = data.items[data.items.length - 1].id;
// 追加新商品 HTML(注意:后端返回的是完整 <div class="col-lg-6..."> 片段)
$('#players').append(data.html);
// 可选:触发动画或提示
console.log(`Loaded ${data.items.length} new products`);
}
} catch (e) {
console.warn('Invalid JSON response:', response);
}
})
.fail(function (xhr) {
console.error('Fetch failed:', xhr.status, xhr.statusText);
});
}
// 每 3 秒轮询一次(避免过于频繁,生产环境建议 5–10s 或改用 SSE/WebSocket)
setInterval(fetchNewProducts, 3000);
});
</script>2. 后端(PHP 示例:/api/get-new-players.php)
<?php
header('Content-Type: application/json; charset=utf-8');
require_once '../config/database.php'; // 引入数据库连接
$lastId = (int)($_GET['last_id'] ?? 0);
$response = ['error' => false, 'message' => '', 'items' => [], 'html' => ''];
try {
$stmt = $pdo->prepare("
SELECT id, playerName, buyPrice, marketPrice, price, image
FROM players
WHERE id > ?
ORDER BY id ASC
LIMIT 20
");
$stmt->execute([$lastId]);
$newPlayers = $stmt->fetchAll(PDO::FETCH_ASSOC);
if (!empty($newPlayers)) {
$html = '';
foreach ($newPlayers as $p) {
$html .= '<div class="col-lg-6 col-xl-3 mb-4">';
$html .= '<div class="card text-center"><div class="card-body">';
$html .= '<div class="row m-b-30">';
$html .= '<div class="col-md-5 col-xxl-6">';
$html .= '<div class="new-arrival-product mb-4 mb-xxl-4 mb-md-0">';
$html .= '<div class="new-arrivals-img-contnent">';
$html .= '<img class="img-fluid" src="' . htmlspecialchars(baseUrl() . '/upload/images/players/' . $p['image']) . '" alt="' . htmlspecialchars($p['playerName']) . '">';
$html .= '</div></div></div>';
$html .= '<div class="col-md-7 col-xxl-6">';
$html .= '<div class="new-arrival-content position-relative">';
$html .= '<h4>' . htmlspecialchars($p['playerName']) . '</h4>';
$html .= '<p>Buy Now Price <span class="item text-success">' . htmlspecialchars($p['buyPrice']) . '</span></p>';
$html .= '<p>Market Price: <span class="item text-success">' . htmlspecialchars($p['marketPrice']) . '</span></p>';
$html .= '<p>Price In Dollar: <span class="item text-success">' . htmlspecialchars($p['price']) . '</span></p>';
$html .= '</div><button type="button" class="btn btn-rounded btn-primary btn-sm">';
$html .= '<span class="btn-icon-left text-primary"><i class="fa fa-shopping-cart"></i></span>Buy</button>';
$html .= '</div></div></div></div></div>';
}
$response['items'] = $newPlayers;
$response['html'] = $html;
}
} catch (Exception $e) {
$response['error'] = true;
$response['message'] = 'Database query failed';
}
echo json_encode($response, JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);⚠️ 关键注意事项
- ID 必须连续且单调递增:last_id 依赖主键自增特性,若业务允许逻辑删除或 ID 不连续,应改用时间戳(created_at > ?)+ 索引优化。
- 防重复与竞态:前端需确保 lastId 严格递进;后端 SQL 使用 ORDER BY id ASC 保证顺序。
- 性能优化:
- 避免高频轮询(≤ 3s),可结合用户活跃状态动态调整间隔;
- 数据库字段加索引:ALTER TABLE players ADD INDEX idx_last_id (id);
- 安全性:所有输出到 HTML 的变量必须 htmlspecialchars() 转义,防止 XSS;API 接口应校验权限(如仅限登录用户访问)。
- 渐进增强:可配合 Intersection Observer 懒加载 + 分页,或升级为 Server-Sent Events(SSE)/WebSocket 实现真正实时推送。
通过上述方案,你将获得一个稳定、安全、可维护的无刷新商品更新机制,显著提升用户体验与系统响应效率。
到这里,我们也就讲完了《实时获取数据库新增商品的技巧》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!
相关阅读
更多>
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
482 收藏
-
454 收藏
-
378 收藏
-
154 收藏
-
472 收藏
-
362 收藏
-
501 收藏
-
296 收藏
-
273 收藏
-
391 收藏
-
373 收藏
-
403 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习