婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新

pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新

熱門標簽:立陶宛地圖標注 中國地圖標注不明確情況介紹表 東平縣地圖標注app 上海企業外呼系統價錢 地圖標注推銷坑人 電銷機器人 長春 怎樣在地圖標注文字 大眾點評400電話怎么申請 河間市地圖標注app

使用Ajax可以異步獲取數據,可以更高效地渲染頁面。

但也存在這一些問題:

再刷新頁面,頁面就會變成初始的狀態

瀏覽器的前進后退功能無效

對搜索引擎的爬蟲抓取不友好

1、

早前會使用瀏覽器的 hash錨點 來解決

不同的hash標記著頁面不同的部分,能修正頁面刷新數據不正確的問題

再通過 onhashchange 事件監聽hash錨點的變化,手動進行前進后退操作,瀏覽器支持度

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(不過好像瀏覽器都忽略了這個參數)

url是某個頁面的標記url(操作只會改變地址欄的url,并不會立馬加載這個url,可以簡單的標記 ?w=a、ajaxPage.html/w=a、w=a,只是一種標記,取值時對照著來就行)

replaceState和pushState的不同是:前者直接替換當前值,后者就是向棧中壓入一個值

window.onpopstate 事件觸發之后,可以通過 history.state獲取到上述方法的第一個json對象

實現部分

HTML

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結果頁

Tips:

使用pushState之后,當前進后退觸發了popstate事件,獲取到相應的json對象

json對象的數據可自定義

可簡單地存儲相關標記再發個請求,或者直接將該標記頁對應的結果直接存起來

隨著后退操作,地址欄url得到了更新,異步的數據也得到了更新

刷新頁面或新打開頁面,就要根據url中的標記去請求數據了

要記住的是,瀏覽器并不會自動加載url這部分標記對應的這個異步內容頁,需要我們去獲取

以上所述是小編給大家介紹的pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • 使用Yii整合的pjax(pushstate+ajax)實現無刷新加載頁面
  • 使用ajax和history.pushState無刷新改變頁面URL示例
  • 使用ajax實現無刷新改變頁面內容和地址欄URL
  • 基于iframe實現類似于ajax的頁面無刷新
  • ajax頁面無刷新 IE下遭遇Ajax緩存導致數據不更新的問題
  • Ajax無刷新Url提交頁面
  • JS+Ajax+Jquery實現頁面無刷新分頁以及分組 超強的實現
  • PHP Ajax實現頁面無刷新發表評論
  • PHP Ajax實現頁面無刷新發表評論
  • pushState實現Ajax無刷新頁面切換

標簽:營口 銅川 本溪 內江 益陽 遼寧 四川 玉樹

巨人網絡通訊聲明:本文標題《pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新》,本文關鍵詞  pushState,replaceState,onpopstate,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新》相關的同類信息!
  • 本頁收集關于pushState、replaceState、onpopstate 實現Ajax頁面的前進后退刷新的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 虎林市| 普安县| 淮滨县| 巨野县| 锡林郭勒盟| 荔波县| 厦门市| 余姚市| 浪卡子县| 黄石市| 革吉县| 姜堰市| 称多县| 蛟河市| 乾安县| 襄城县| 多伦县| 陈巴尔虎旗| 乌兰县| 衡山县| 建阳市| 芦山县| 昆明市| 永城市| 锦屏县| 平阳县| 临高县| 六安市| 安宁市| 武宣县| 阿克| 古浪县| 泽普县| 曲阜市| 黄大仙区| 大荔县| 潮安县| 宜兰市| 柳州市| 北辰区| 兴仁县|