0

0

如何通过 jQuery 实现局部 div 的无刷新动态重载

碧海醫心

碧海醫心

发布时间:2026-01-15 11:41:17

|

559人浏览过

|

来源于php中文网

原创

如何通过 jQuery 实现局部 div 的无刷新动态重载

本文详解如何使用 jquery 的 `.load()` 方法仅刷新页面中指定的 `

` 元素,避免整页重载,重点解决脚本未执行、jquery 未引入及语法错误等常见问题,并提供可直接运行的完整示例。

在 Web 开发中,为提升用户体验和减少服务器压力,常需“局部刷新”——即仅更新页面中某一部分内容(如一个 div),而非重新加载整个页面。jQuery 提供的 .load() 方法是实现这一目标最简洁高效的方式之一。

✅ 正确实现原理

.load() 支持从当前页面(或任意 URL)中提取指定选择器的内容并注入目标元素。关键语法如下:

$('#reloadable').load(location.href + ' #reloadable');

该语句含义是:向当前页面地址发起 AJAX 请求,获取响应 HTML 中 #reloadable 元素的内部 HTML,并用其替换当前页面中 #reloadable 的内容。由于 PHP 文件(如 rand.php)在服务端执行,每次请求都会重新生成随机数,因此能实现真正的“动态刷新”。

⚠️ 常见错误与修复要点

  1. jQuery 未引入
    原代码中缺失 jQuery 库,导致 $ 未定义,load() 方法根本无法调用。必须在使用前引入 jQuery(推荐 CDN):

  2. 脚本类型拼写错误
    原代码中

  3. onclick 调用无需 javascript: 前缀
    onclick="javascript:refreshDiv();" 中的 javascript: 是冗余的(仅用于 等非事件属性中)。直接写 onclick="refreshDiv();" 更规范。

  4. PHP 包含逻辑需确保可独立执行
    rand.php 应仅输出纯内容(如 echo rand(0,10);),不包含 HTML 结构或依赖外部变量,否则重复加载时可能出错。

    聚蜂消防BeesFPD
    聚蜂消防BeesFPD

    关注消防领域的智慧云平台

    下载

✅ 完整可运行示例

文件结构:

  • index.html
  • rand.php

rand.php:

index.html:




  局部刷新示例
  
  


  
? 提示:location.href + ' #reloadable' 利用了 jQuery 的“片段加载”特性(fragment loading),它会自动解析响应 HTML 并提取匹配的选择器内容,无需后端额外接口。

? 注意事项与最佳实践

  • 同源限制:.load() 受浏览器同源策略约束,仅支持加载同域资源。
  • 错误处理:生产环境建议添加失败回调,例如:
    $('#reloadable').load(location.href + ' #reloadable', function(response, status, xhr) {
      if (status === "error") {
        $('#reloadable').html("加载失败,请重试");
      }
    });
  • 性能优化:若 rand.php 逻辑复杂,建议将其封装为独立 API 接口(如 /api/rand),避免重复解析整个 HTML 页面。
  • 替代方案:现代项目可考虑使用 fetch() + innerHTML 或框架(如 Vue/React)的响应式更新,但 jQuery .load() 仍是最轻量级的原生兼容方案。

通过以上配置,你将获得一个稳定、可复用的局部刷新功能——点击按钮,

内的随机数即时更新,页面其余部分毫秒级无感,真正实现优雅的动态交互。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2534

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1604

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1498

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1416

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1445

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

6

2026.01.15

热门下载

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

精品课程

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

共137课时 | 8.7万人学习

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

共6课时 | 7万人学习

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

共13课时 | 0.9万人学习

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

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