pjax 是一个jQuery插件,它使用
ajax
和pushState
来实现快速的浏览体验,包括真正的固定连接,页面标题和工做返回按钮。javascript
ajax缺点是破坏了浏览器的前进后退,由于ajax的请求不会留在历史记录中。pjax就不同了,pjax被解释成ajax+pushState的封装,由于它把ajax的请求写入历史记录,并反映在地址栏,这样用户就能愉快地使用前进后退了。pjax有好几个实现方法,这里使用最经常使用的jQuery库,使用jquery.pjax.js。演示代码的服务器端使用PHP脚本语言。php
Pjax用在那儿?就说百度云盘吧,这个你们确定都用过。百度云盘PC端,在点击打开某个文件夹后会打开这个文件夹下的文件,其实显示文件的这个div就用到了pjax技术。地址栏变换,内容更换,可是倒是一个ajax请求。等到后退的时候,没必要从新请求上一层文件夹的内容,由于是存在在历史记录中的。并且,开发者还能够选择时候使用cache和storage缓存。html
<!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.phpjava
<?php echo "<div style='background:red;'>第一页</div>";
res2.phpjquery
<?php echo "<div style='background:red;'>第二页</div>";
解释:$(document).pjax('a', '#Container')
其中 a
是触发元素,#container
是装载 pjax
返回内容的容器,下面也是这样。git
<!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>
服务器端代码:github
res3.php:ajax
<?php echo "<div style='background:red;'>第三页</div>";
window.history.pushState(state, title, url); // https://developer.mozilla.org/zh-CN/docs/Web/API/History/pushState // @状态对象: 记录历史记录点的额外对象,能够为空. // @页面标题: 目前全部浏览器都不支持. // @可选的URL: 浏览器不会检查URL是否存在,只改变URL.URL必须同域,不能跨域.
PJAX其实就是HTML5 window.history.pushState(state, title, url)这个新的API加上传统的AJAX技术,通常用来实现无刷新的页面加载.pushState的做用主要是:改变URL和添加返回历史.这样AJAX无刷新加载页面后,用户还能够正常进行后退和前进,JS的window.history.back()和window.history.forward()也能正常工做.下面就是一个用pushState + jQuery AJAX实现的无刷新的页面加载,不支持的浏览器则自动退化成打开原始的连接打开形式.json
index.php:segmentfault
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Index</title> <script src="jquery.js"></script> </head> <body> <div id="main"> <a href="data.php">data.php</a> <script> $(document).ready(function() { $('#main').on('click','a',function(e) { if(window.history.pushState) { e.preventDefault(); //不跟随原连接跳转 url = $(this).attr('href'); $.ajax({ async: true, type: 'GET', url: 'data.php', data: 'pjax=1', success: function(data) { window.history.pushState(null, null, url); //改变URL和添加返回历史 document.title = data.title; //设置标题 $('#main').html(data.main); //设置内容 } }); } else { return; //低版本IE8等不支持HTML5 pushState,直接返回进行连接跳转 } }); }); </script> </div> </body> </html>
data.php:
<?php if(isset($_GET['pjax'])) { //PJAX请求返回JSON $arr['title'] = 'Data'; $arr['main'] = '<h1>Data Content</h1>'; //下面这两句是把PHP数组转成JSON对象返回 header('Content-Type: application/json; charset=utf-8'); echo json_encode($arr); } else { //常规请求返回HTML ?>
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Data</title> <script src="jquery.js"></script> </head> <body> <div id="main"><h1>Data Content</h1></div> </body> </html> <?php } ?>
注意,JS统计代码应该放到main块里面才能正常统计页面访问数.
小结:Pjax实际就是从服务器端返回一段代码片断,而不用刷新页面,而且同时对 url
地址进行修改,这样能够节省资源加载,提高页面加载速度。