91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-07-23 10:41:59 來源:億速云 閱讀:132 作者:小新 欄目:web開發

這篇文章主要為大家展示了“如何通過JS攔截 pushState和replaceState事件”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“如何通過JS攔截 pushState和replaceState事件”這篇文章吧。

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事件”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

镇赉县| 大城县| 三河市| 神池县| 巴塘县| 木兰县| 通许县| 肥西县| 林口县| 建德市| 富裕县| 特克斯县| 昌都县| 扶绥县| 邢台县| 巫山县| 昭觉县| 兴安盟| 双峰县| 嘉定区| 兴山县| 洛浦县| 阿鲁科尔沁旗| 凯里市| 永善县| 上犹县| 连州市| 夏河县| 新巴尔虎左旗| 云浮市| 遂宁市| 景泰县| 阳高县| 和平区| 金乡县| 象州县| 应城市| 宜丰县| 稷山县| 牟定县| 新野县|