亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > WEB開發 > 正文

詳解JavaScript操作URL的方法(單頁應用常用)

2024-04-27 15:06:32
字體:
來源:轉載
供稿:網友

詳解javaScript操作URL的方法(單頁應用常用)

Javascript擁有許多可以操作瀏覽器歷史記錄的方法,不管是普通頁面跳轉,還是單頁應用哈希值變化,我們都會經常與這些方法打交道,尤其在單頁應用中這些方法幾乎是頁面路由的核心方法。本文將詳細討論這些方法。

1.document.location

location是最有用的BOM對象之一,它提供了與當前窗口中加載的文檔有關的信息,還提供了一些導航功能。事實上,location對象既是window對象的屬性,又是document對象的屬性。換句話說,window.location和document.location是同一個對象。這里推薦大家使用document.location的寫法,以適應非瀏覽器文檔環境。 除去為a標簽設置的href屬性,大家最常用的跳轉方式一定就是:window.location.href=”xxx”;實際上,上面這句代碼真正執行的是location.assign方法。簡而言之,下面三中URL跳轉的寫法完全等同,都會立即打開新的URL并在瀏覽器的歷史記錄中生成一條記錄:

document.location.assign("xxx");document.location="xxx";document.location.href="xxx";

需要注意的是,如果通過這種方式跳轉的URL與當前URL完全相同,則頁面會刷新,但是瀏覽器歷史記錄不會新增。

2.location.replace

功能幾乎與location.href=”xxx”;完全相同,只有一個區別,location.replace會在瀏覽器的歷史記錄中生成一條記錄,并替換前一條記錄。舉個例子,當我們打開“a.html”頁面,頁面內有如下兩行代碼:

document.location.href="c.html";document.location.replace("b.html");

瀏覽器先通過location.href的方式跳轉到c.html,接著又使用location.replace跳轉到b.html。此時點擊瀏覽器的后退按鈕,瀏覽器會直接返回a.html,因為c.html這條歷史記錄被replace覆蓋了。

3.window.onhashchange

我們可以通過如下代碼形式來監聽瀏覽器URL的哈希值變化:

window.addEventListener("hashchange",function(){ //do something},false);//以下代碼都會觸發hashchange事件document.location.hash="#a=1";document.location.href="b.html#b=1";document.location.replace("c.html#c=1");

當我們通過改寫location的方式引起瀏覽器URL哈希值變化時,hashchange事件就會觸發。如果URL重寫導致了頁面刷新(例如改變了URL查詢參數,或者直接跳向一個跨域地址),hashchange事件會直接被跳過。請注意,URL哈希值變化不一定總是會觸發hashchange事件,下面要介紹的方法就是改動URL但不觸發hashchange。

4. history.pushState

pushState方法接收三個參數:一個記錄歷史狀態的對象(該對象會在popstate事件觸發時被傳入,有640K的大小限制);一個代表歷史記錄標題的字符串;一個與當前URL同源的地址。典型的使用方式如下:

history.pushState({}, "", "b.html");

history.pushState()方法會將URL設置為一個同源URL值,在此之后發送的Ajax請求的Referrer頭部都會使用這個新的值,同時在瀏覽器歷史記錄中生成一條新的歷史記錄。但是pushState方法不會刷新頁面,pushState引起的URL哈希值變化也不會觸發hashchange事件。pushState如果設置了一條與當前URL完全相同的地址,瀏覽器的歷史記錄中仍然會新增一條記錄。

5.history.replaceState

該方法與history.pushState基本相同,唯一的區別就是replaceState會像location.replace一樣覆蓋先前歷史記錄。 關于history.pushState和history.replaceState的更多介紹: https://developer.mozilla.org/zh-CN/docs/DOM/Manipulating_the_browser_history

6.window.onpopstate

我們可以通過如下代碼形式來監聽瀏覽器的popstate事件:

window.addEventListener("popstate",function(event){ //do something},false);

與hashchange事件類似,popstate會在任何URL變化時觸發(hashchange只會在哈希值變化時觸發),并且history.pushState和history.replaceState也不會觸發popstate事件。只有在瀏覽器后退、前進、重寫哈希值的情況下才會觸發popstate事件。如果URL重寫導致了頁面刷新(例如改變了URL查詢參數,或者直接跳向一個跨域地址),popstate事件會直接被跳過。 這里請注意一下代碼中傳給事件函數的參數“event”,event參數中包含state對象,這個state對象就是在調用history.pushState和history.replaceState方法是傳入的第一個狀態參數,我們可以通過這種狀態傳遞方式來對歷史記錄進行一定處理。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性xxxx极品高清hd直播| 精品丝袜一区二区三区| 91在线色戒在线| 97视频在线观看免费高清完整版在线观看| 欧美老少做受xxxx高潮| 日本欧美一二三区| 亚洲日本中文字幕免费在线不卡| 亚洲人在线观看| 国产成人久久精品| 亚洲综合中文字幕在线观看| 亚洲色图狂野欧美| 91在线观看免费高清完整版在线观看| 日韩美女av在线免费观看| www.欧美精品| 欧美日韩性视频在线| 国产精品视频免费观看www| 亚洲午夜未满十八勿入免费观看全集| 福利一区视频在线观看| 欧美日韩激情网| 国产a∨精品一区二区三区不卡| 亚洲黄在线观看| 久久久久久久久久久人体| 国产成人中文字幕| 在线观看欧美成人| 日韩欧美亚洲成人| 精品偷拍一区二区三区在线看| www.亚洲人.com| 国产精品久久久久久久久久久久久久| 美女久久久久久久久久久| 欧美电影在线免费观看网站| 最近2019中文免费高清视频观看www99| 久久中文精品视频| 午夜免费日韩视频| 日韩在线观看你懂的| 久久久久久久久久亚洲| 亚洲一区二区三区乱码aⅴ| 亚洲精品日韩丝袜精品| 国外成人在线播放| 欧美日韩在线另类| 亚洲男人的天堂在线播放| 韩国福利视频一区| 日韩va亚洲va欧洲va国产| 欧美在线一级视频| 在线播放亚洲激情| 日韩欧美aⅴ综合网站发布| 国产999精品久久久影片官网| 91久久精品国产91久久性色| 亚洲a在线播放| 亚洲影院在线看| 欧美日韩成人在线视频| 中文字幕日韩在线视频| 久久综合九色九九| 久热99视频在线观看| 亚洲欧美国产精品va在线观看| 国产日产亚洲精品| 国产精品欧美亚洲777777| 国产精品久久久久免费a∨| 91日本在线视频| 久久99久久99精品中文字幕| 国产亚洲精品日韩| 97在线精品国自产拍中文| 精品国产电影一区| 国产精品久久久久久av福利| 国产日韩视频在线观看| 日韩精品中文字幕在线播放| 欧美日韩不卡合集视频| 91国产美女在线观看| 91精品国产乱码久久久久久久久| 精品亚洲精品福利线在观看| 国精产品一区一区三区有限在线| 国产精品久久精品| 中文字幕亚洲字幕| 精品成人久久av| 日韩av中文字幕在线| 91精品久久久久久综合乱菊| 日韩视频免费中文字幕| 亚洲国产欧美在线成人app| 久久久久久久成人| 亚洲国内高清视频| 久久伊人免费视频| 有码中文亚洲精品| 伦理中文字幕亚洲| 日韩av电影手机在线观看| 川上优av一区二区线观看| 少妇高潮久久久久久潘金莲| 久久久91精品国产| 国产成人在线一区| 亚洲最大激情中文字幕| 秋霞av国产精品一区| 岛国精品视频在线播放| 色婷婷久久av| 日韩中文字幕在线| 欧美电影免费观看大全| 精品久久久久久中文字幕| 欧美午夜性色大片在线观看| 91高清免费在线观看| 国产91精品青草社区| 欧美午夜片欧美片在线观看| 欧美午夜影院在线视频| 日韩亚洲欧美中文高清在线| 亚洲无线码在线一区观看| 国产精品国产福利国产秒拍| 日韩精品免费视频| 欧洲成人在线视频| 精品久久久中文| 亚洲综合社区网| 俺也去精品视频在线观看| 国产精品免费观看在线| 欧美性猛交xxxx乱大交极品| 91麻豆国产语对白在线观看| 亚洲女在线观看| 色哟哟亚洲精品一区二区| 国产欧美日韩中文字幕在线| 日韩精品免费综合视频在线播放| 精品美女永久免费视频| 欧美xxxx14xxxxx性爽| 亚洲一二三在线| 亚洲福利视频久久| 日韩av在线免费看| 久久久久久18| 亚洲国产欧美精品| 国产狼人综合免费视频| 欧美大全免费观看电视剧大泉洋| 欧美性xxxx| 亚洲国产精品va在线观看黑人| 亚洲欧美精品一区| 91福利视频在线观看| 国产精品久久久91| 久久国产精品久久国产精品| 精品久久久国产| 亚洲欧美色婷婷| 亚洲a级在线播放观看| 国产自产女人91一区在线观看| 欧美日韩在线观看视频小说| 亚洲影院色无极综合| 欧美一级大胆视频| 精品久久久久久亚洲精品| 欧美成人四级hd版| 68精品国产免费久久久久久婷婷| 2019亚洲日韩新视频| 久久久久国色av免费观看性色| 欧美亚洲在线播放| 亚洲精品美女网站| 日本精品免费观看| 国产精品入口免费视| 57pao国产成人免费| 欧美性猛交xxxx乱大交蜜桃| 亚洲精品99久久久久中文字幕| 国产不卡一区二区在线播放| 亚洲精品动漫久久久久| 国内自拍欧美激情| 亚洲成**性毛茸茸| 国产精品美女午夜av| 亚洲国产成人91精品| 97成人超碰免| 日韩免费在线观看视频| 亚洲片国产一区一级在线观看| 国产精品99免视看9| 国产在线精品播放| 国产精品久久久久久久久久ktv| 国产精品毛片a∨一区二区三区|国| 欧美激情视频网站| 91色琪琪电影亚洲精品久久| 欧美中文字幕视频|