0

0

实时获取数据库新增商品而不刷新页面

花韻仙語

花韻仙語

发布时间:2026-02-15 12:16:06

|

265人浏览过

|

来源于php中文网

原创

实时获取数据库新增商品而不刷新页面

本文介绍如何通过 ajax 轮询结合后端增量查询,实现在不刷新页面的前提下动态加载新上架商品,避免全量重载导致的性能与体验问题。

本文介绍如何通过 ajax 轮询结合后端增量查询,实现在不刷新页面的前提下动态加载新上架商品,避免全量重载导致的性能与体验问题。

在电商类或商品展示型 Web 应用中,用户期望实时感知库存或新品上架变化——例如当管理员后台添加一款新球衣,前端店铺列表应“自动出现”该商品,而非依赖手动刷新或整页轮询。你当前使用的 setInterval + .load() 全量重载方式存在明显缺陷:每次请求都重新渲染全部商品,不仅浪费带宽与服务端资源,还可能引发重复渲染、状态丢失(如已添加至购物车的商品被覆盖)、DOM 闪烁等问题。

要真正实现增量更新,核心思路是:前端记住最后获取的商品 ID(或时间戳),每次仅向后端请求“此后新增的数据”,后端返回对应 HTML 片段或结构化 JSON,前端追加到现有列表末尾

✅ 正确实现步骤

1. 前端:使用 fetch 或 jQuery AJAX 进行轻量轮询

以下为优化后的 jQuery 示例(兼容性好,逻辑清晰):

$(document).ready(function () {
    let lastFetchedId = 0; // 初始值,假设产品表主键为自增整数

    function fetchNewProducts() {
        $.get('/api/get-new-products.php', {
            last_id: lastFetchedId
        })
        .done(function (response) {
            try {
                const data = JSON.parse(response);
                if (data.success && Array.isArray(data.products) && data.products.length > 0) {
                    // 更新最后ID(取数组中最大id,确保幂等)
                    const maxId = Math.max(...data.products.map(p => p.id));
                    lastFetchedId = Math.max(lastFetchedId, maxId);

                    // 将新商品HTML片段追加到容器(注意:此处需后端返回HTML字符串)
                    $('#players').append(data.html); 

                    // 或更推荐:前端模板渲染(见下方说明)
                    // data.products.forEach(renderProductCard);
                }
            } catch (e) {
                console.warn('Invalid response format:', e);
            }
        })
        .fail(function (xhr) {
            console.error('Failed to fetch new products:', xhr.status, xhr.statusText);
        });
    }

    // 每3秒检查一次(避免过于频繁,建议 2–5 秒)
    setInterval(fetchNewProducts, 3000);
});

⚠️ 注意事项:

  • 勿使用 .load() 全量替换:$('#players').load(...) 会清空原有内容再插入,破坏已有 DOM 状态(如事件绑定、滚动位置、选中态)。
  • ID 必须可靠递增:若产品表主键非严格自增(如 UUID、软删除后复用 ID),应改用 created_at 时间戳字段,并配合 last_timestamp 参数。
  • 防抖与节流:生产环境建议加入失败重试退避(如指数退避)、错误计数熔断机制。

2. 后端(PHP 示例):按增量条件查询并返回结构化数据

/api/get-new-products.php 应返回标准 JSON,不直接输出 HTML(利于前后端分离与可维护性):

I-Shop购物系统
I-Shop购物系统

部分功能简介:商品收藏夹功能热门商品最新商品分级价格功能自选风格打印结算页面内部短信箱商品评论增加上一商品,下一商品功能增强商家提示功能友情链接用户在线统计用户来访统计用户来访信息用户积分功能广告设置用户组分类邮件系统后台实现更新用户数据系统图片设置模板管理CSS风格管理申诉内容过滤功能用户注册过滤特征字符IP库管理及来访限制及管理压缩,恢复,备份数据库功能上传文件管理商品类别管理商品添加/修改/

下载
<?php
header('Content-Type: application/json; charset=utf-8');
require_once 'db.php'; // 假设已封装 PDO 连接

$lastId = (int)($_GET['last_id'] ?? 0);
$stmt = $pdo->prepare("
    SELECT id, playerName, buyPrice, marketPrice, price, image 
    FROM players 
    WHERE id > ? 
    ORDER BY id ASC 
    LIMIT 20
");
$stmt->execute([$lastId]);
$products = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 构建纯数据响应(推荐)
$html = '';
foreach ($products as $p) {
    $html .= <<<HTML
<div class="col-lg-6 col-xl-3">
    <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() ? alt="实时获取数据库新增商品而不刷新页面" >/upload/images/players/{$p['image']}" alt="{$p['playerName']}">
                        </div>
                    </div>
                </div>
                <div class="col-md-7 col-xxl-6">
                    <div class="new-arrival-content position-relative">
                        <h4>{$p['playerName']}</h4>
                        <p>Buy Now Price <span class="item text-success">{$p['buyPrice']}</span></p>
                        <p>Market Price: <span class="item text-success">{$p['marketPrice']}</span></p>
                        <p>Price In Dollar: <span class="item text-success">{$p['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>
HTML;
}

echo json_encode([
    'success' => true,
    'count' => count($products),
    'products' => $products, // 保留原始数据供前端扩展(如添加“新标”角标)
    'html' => $html
]);

3. 进阶建议:告别轮询,拥抱现代方案

  • Server-Sent Events (SSE):服务端主动推送,低延迟、轻量,适合单向通知(如“有新品上架”)。
  • WebSocket:全双工通信,适用于高实时性场景(如拍卖、库存秒杀)。
  • 前端轮询优化:使用 AbortController 防止请求堆积;结合 visibilitychange 事件,在标签页不可见时暂停轮询。

总结

真正的“无刷新更新”不是反复重绘整个区域,而是精准识别增量、最小化传输、安全追加渲染。从 setInterval + .load() 切换到 “ID 记忆 + 增量查询 + append” 模式,是提升用户体验与系统健壮性的关键一步。同时,请始终将轮询间隔设为合理值(≥2s),并在生产环境逐步过渡至 SSE 或 WebSocket 方案。

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

441

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

544

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

318

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

154

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

318

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

403

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

510

2023.12.04

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

139

2026.02.13

热门下载

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

精品课程

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

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