时间:2021-05-26
ajax缺点是破坏了浏览器的前进后退,因为ajax的请求不会留在历史记录中。pjax就不一样了,pjax被解释成ajax+pushState的封装,因为它把ajax的请求写入历史记录,并反映在地址栏,这样用户就能愉快地使用前进后退了。pjax有好几个实现方法,这里使用最常用的Jquery库,使用jquery.pjax.js。演示代码的服务器端使用PHP脚本语言。
Pjax用在那儿?就说百度云盘吧,这个大家肯定都用过。百度云盘PC端,在点击打开某个文件夹后会打开这个文件夹下的文件,其实显示文件的这个div就用到了pjax技术。地址栏变换,内容更换,但是却是一个ajax请求。等到后退的时候,不必重新请求上一层文件夹的内容,因为是存在在历史记录中的。而且,开发者还可以选择时候使用cache和storage缓存。
DEMO1:
客户端:
服务器端:
res1.php
res2.php
解释:$(document).pjax('a', '#container')其中a是触发元素,#container是装载pjax返回内容的容器,下面也是这样。
DEMO2:
<!DOCTYPE html><html><head> <title>pjax</title> <meta charset="utf-8"></head><body> <h1>My Site</h1> <div> Go to <a href="res1.php">第一页</a>.<a href="res2.php">第二页</a> </div> <div id="container"></div> </body><script src="../jquery-2.1.4.min.js"></script><script src="../jquery.pjax.js"></script><script type="text/javascript">$(document).pjax('a', '#container')</script></html>客户端:
<!DOCTYPE html><html><head> <title>pjax</title> <meta charset="utf-8"></head><body> <h1>My Site</h1> <div> <input type="button" id="clickMe" value="GO"> </div> <div id="container"></div> </body><script src="../jquery-2.1.4.min.js"></script><script src="../jquery.pjax.js"></script><script type="text/javascript">$(function(){ $('#clickMe').click(function(){ $.pjax({ url: './res3.php', container: '#container' }); });});</script></html>服务器端代码:
res3.php:
<?php echo "<div style='background:red;'>第三页</div>";源码:jQuery pjax
总结:
此篇文章总结了一些大家常见的jQuery pjax 应用示例,喜欢的同学可以参考借鉴一下。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1、首先到jQuery官网下载js库,网址为http://jquery.com/2、建立一个jQuery示例的项目。3、将js库放到jQuery示例的项目中。4
《jQuery权威指南》第1章jQuery开发入门,本章通过循续渐进的方式,先从jQuery的基础概念入手,介绍jQuery库的下载,引入简单应用方法;后部分侧
pjax是一个jQuery插件,它使用ajax和pushState来实现快速的浏览体验,包括真正的固定链接,页面标题和工作返回按钮。ajax缺点是破坏了浏览器的
当我用defunkt/jquery-pjax载入Yii2的ActiveForm时发生一个错误,正常情况下是ActiveForm的两个js应该先载入,而实际情况是
SpringBoot应用服务启动参照官方示例工程可以快速搭建简单SpringBoot应用,官方连接如下:http://projects.spring.io/sp