偵測即時導覽的位置雜湊變更
使用Ajax 和雜湊進行導覽時,確定window.location.hash 是否已更改改變變得至關重要。雖然傳統方法可能在文件載入時起作用,但在使用瀏覽器的後退按鈕導航時,它們無法捕獲哈希變更。
瀏覽器支援限制
不幸的是,瀏覽器本身不支援提供一個事件來監視位置雜湊變更。這種限制對即時導航更新提出了挑戰。
解決方案:間隔輪詢
最可靠的解決方案是設定一個間隔,不斷檢查當前雜湊並進行比較它與之前的值。當發生變化時,可以觸發事件來通知訂閱者。雖然並不理想,但這種方法可以有效地檢測哈希更改,正如流行的“reallysimplehistory”庫所證明的那樣。
jQuery 抽象
如果您的專案使用 jQuery,則更容易存取選項出現。 jQuery 的抽象化允許監聽 window 物件上的「hashchange」事件,提供更簡單的解決方案。
$(window).on('hashchange', function() { // Handle hash change event });
但是,由於本機瀏覽器對「hashchange」的支援仍然不一致,jQuery 採用了「特殊事件」功能。此功能使您能夠設定程式碼來檢查本機支持,並在缺乏本機支援時觸發輪詢和事件觸發。
結論
儘管缺少本機瀏覽器支持,利用間隔輪詢或jQuery 的抽象提供了監視位置哈希更改的有效方法,從而在您的Web 應用程式中啟用複雜的即時導航技術。
以上是如何可靠地檢測「window.location.hash」中的變化以進行即時導航?的詳細內容。更多資訊請關注PHP中文網其他相關文章!