bl双性强迫侵犯h_国产在线观看人成激情视频_蜜芽188_被诱拐的少孩全彩啪啪漫画

如何通過JS攔截pushState和replaceState事件

這篇文章主要為大家展示了“如何通過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。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

小程序開發