這篇文章主要為大家展示了“如何通過JS攔截 pushState和replaceState事件”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何通過JS攔截 pushState和replaceState事件”這篇文章吧。
成都創新互聯長期為1000+客戶提供的網站建設服務,團隊從業經驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯網生態環境。為鐵山港企業提供專業的成都網站建設、網站制作,鐵山港網站改版等技術服務。擁有10余年豐富建站經驗和眾多成功案例,為您定制開發。
history.pushState 和 history.replaceState 可以在不刷新當前頁面的情況下更改URL,但是這樣就無法獲取通過AJAX得到的新頁面的內容了。
雖然各種HTML5文檔說 window.onpopstate 事件可以攔截 pushState 的消息,但在實際的測試中, onpopstate 根本沒有任何作用,無法攔截 pushState 的消息。
經過Google一番,才找到了正確獲取 pushState 事件的代碼
// Add this: var _wr = function(type) { var orig = history[type]; return function() { var rv = orig.apply(this, arguments); var e = new Event(type); e.arguments = arguments; window.dispatchEvent(e); return rv; }; }; history.pushState = _wr('pushState'); history.replaceState = _wr('replaceState'); // Use it like this: window.addEventListener('pushState', function(e) { console.warn('THEY DID IT AGAIN!'); }); window.addEventListener('replaceState', function(e) { console.warn('THEY DID IT AGAIN!'); });
這段代碼改寫了 history 中原來的函數,然后自己激活一個事件
這樣就可以解決 pushState 無法激活事件的問題了
另外記得最好將這段代碼放在文檔加載前執行
以上是“如何通過JS攔截 pushState和replaceState事件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!
網站欄目:如何通過JS攔截pushState和replaceState事件
URL網址:http://vcdvsql.cn/article44/pejdee.html
成都網站建設公司_創新互聯,為您提供網站建設、關鍵詞優化、App開發、網站制作、靜態網站、網頁設計公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯