ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# [jQuery pjax 简单入门](https://www.cnblogs.com/kiscall/p/4940101.html) [https://github.com/defunkt/jquery-pjax](https://github.com/defunkt/jquery-pjax)! 以前我们点击a链接的时候总是会刷新整个页面并跳转到新页面,中间可以很明显的看到短暂的白屏。pjax就很好的解决了这问题。 pjax的原理很简单,就是发送一个ajax请求,获取html代码,再把相关代码应用到指定容器中,就完成了pjax。pjax除了解决跳转白屏以外,还能替代iframe,让前端不得不使用iframe的场景大大减少。 ``` <a class="leftPaneItem" onclick="writeMail()">写邮件</a> <div id="control"></div> ``` 如果想快速将页面内所有a标签替换成pjax的跳转方式可以写成这样: ``` $(document).pjax('a', '#container') ```   Pjax是ajax的升级版,怎么理解呢,当初学习ajax的时候讲了ajax的优缺点,其中一个缺点是破坏了浏览器的前进后退,因为ajax的请求不会留在历史记录中。pjax就不一样了,pjax被解释成ajax+pushState的封装,因为它把ajax的请求写入历史记录,并反映在地址栏,这样用户就能愉快地使用前进后退了。pjax有好几个实现方法,这里使用最常用的Jquery库,使用jquery.pjax.js。演示代码的服务器端使用PHP脚本语言。   Pjax用在那儿?就说百度云盘吧,这个大家肯定都用过。百度云盘PC端,在点击打开某个文件夹后会打开这个文件夹下的文件,其实显示文件的这个div就用到了pjax技术。地址栏变换,内容更换,但是却是一个ajax请求。等到后退的时候,不必重新请求上一层文件夹的内容,因为是存在在历史记录中的。而且,开发者还可以选择时候使用cache和storage缓存。 **用法** ~~~ <script type="text/javascript"> $(function () { // 跳转页 $(document).on('pjax:complete', function (event, xhr, textStatus, options) { var url = xhr.getResponseHeader('X-PJAX-URL'); if (url) { $.pjax({url: url, container: '.content-wrapper'}) } }); // a 链接 $(document).pjax('a[target!=_blank]', '.content-wrapper'); // form 表单 $(document).on('submit', 'form[data-pjax]', function (event) { $.pjax.submit(event, '.content-wrapper'); }); // 阻止超时导致的链接跳转(ajax默认超时时间650毫秒,超时后强制刷新整个页面) $(document).on('pjax:timeout', function (event) { event.preventDefault() }); // 重新加载 //$.pjax.reload('.content-wrapper'); }) ~~~ DEMO1: 客户端: ~~~ <!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> ~~~ 服务器端: res1.php ~~~ <?php echo "<div style='background:red;'>第一页</div>"; ~~~ res2.php ~~~ <?php echo "<div style='background:red;'>第二页</div>"; ~~~ 解释:$(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> <input type="button" id="th" 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(){ $('#th').click(function(){ $.pjax({ url: './res3.php', container: '#container' }); }); }); </script> </html> ~~~ 服务器端代码: res3.php: ~~~ <?php echo "<div style='background:red;'>第三页</div>"; ~~~