2、
随后出现一种 hashbang 的技术,即在url后加上标记 #!/myPath 来解决上述的问题
通过一个路径定义一个页面部分,在单页面应用中可常见到(Angular中已经封装了)。但好像只有google真正支持了对该路径的爬取
3、
HTML5的新特性做了助力,通过pushState、replaceState 这两个新的history方法和 onpopstate 这个window事件,解决了上述三个问题
当然,也因为是HTML5的新特性,在旧版本浏览器上支持度不好的,建议是再用hashbang的方法来兼容
本文主要讲讲pushState这几个新东西
文字太枯燥了,先看看图示直接点感受
这个栗子目的是:初始值为0,通过异步请求自增值,可以前进或后退以及刷新,新打开一个url后也能获取相应的数据
history.pushState(state, title, url)history.replaceState(state, title, url)其中state是个json对象,可以自定义存放一些数据,title即是这个url对应的标签title(不过好像浏览器都忽略了这个参数)
<div class="push-state-test"><input type="button" id="ajax-test-btn" value="Ajax获取"><p>value: <span id="ajax-test-val">0</span></p></div>JS
var $val = $("#ajax-test-val"),// 获取当前页面的标记m = window.location.search.match(/?val=(d+)/);// 新进入页面,通过url中的标记初始化数据if (m) {increaseVal(m[1] - 1);}// 请求function increaseVal(val) {$.post("ajax-test.php", {val: val}, function(newVal) {$val.text(newVal);// 存储相关值至对象中var state = {val: newVal,title: "title-" + newVal,url: "?val=" + newVal}// 将相关值压入history栈中window.history.pushState && window.history.pushState(state, state.title, state.url);});}$("#ajax-test-btn").click(function() {increaseVal(parseInt($val.text(), 10));});// 浏览器的前进后退,触发popstate事件window.onpopstate = function() {var state = window.history.state;console.log(state)// 直接将值取出,或再次发个ajax请求$val.text(state.val);window.history.replaceState && window.history.replaceState(state, state.title, state.url);};PHP
<?php$val = $_REQUEST["val"];echo $val + 1;?>这里通过?val=num 的方式,标记了不同的ajax结果页