這篇文章主要介紹了pushState、replaceState、onpopstate 實現Ajax頁面的前進後退刷新的相關資料,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
使用Ajax可以非同步獲取數據,可以更有效率地渲染頁面。
但也存在這一些問題:
#再刷新頁面,頁面就會變成初始的狀態
瀏覽器的前進後退功能無效
對搜尋引擎的爬蟲抓取不友善
1、
早前會使用瀏覽器的hash錨點來解決
不同的hash標記著頁面不同的部分,能修正頁面刷新資料不正確的問題
再透過onhashchange 事件監聽hash錨點的變化,手動進行前進後退操作,瀏覽器支援度
2、
接著出現一種hashbang 的技術,即在url後面加上標記#!/myPath 來解決上述的問題
透過一個路徑定義一個頁面部分,在單頁面應用程式中可常見到(Angular中已經封裝了)。但好像只有google真正支援了對該路徑的爬取
3、
HTML5的新特性做了助力,透過pushState、replaceState 這兩個新的history方法和onpopstate 這個window事件,解決了上述三個問題
當然,也因為是HTML5的新特性,在舊版瀏覽器上支持度不好的,建議是再用hashbang的方法來兼容
本文主要講講pushState這幾個新東西
文字太枯燥了,先看看圖示直接點感受
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
<p class="push-state-test"> <input type="button" id="ajax-test-btn" value="Ajax获取"> <p>value: <span id="ajax-test-val">0</span></p> </p>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頁面的前進後退刷新的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

Python和JavaScript的未來趨勢包括:1.Python將鞏固在科學計算和AI領域的地位,2.JavaScript將推動Web技術發展,3.跨平台開發將成為熱門,4.性能優化將是重點。兩者都將繼續在各自領域擴展應用場景,並在性能上有更多突破。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

是的,JavaScript的引擎核心是用C語言編寫的。 1)C語言提供了高效性能和底層控制,適合JavaScript引擎的開發。 2)以V8引擎為例,其核心用C 編寫,結合了C的效率和麵向對象特性。 3)JavaScript引擎的工作原理包括解析、編譯和執行,C語言在這些過程中發揮關鍵作用。

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

WebStorm Mac版
好用的JavaScript開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具