溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

window.location對(duì)象使用說(shuō)明

發(fā)布時(shí)間:2020-06-30 20:07:07 來(lái)源:網(wǎng)絡(luò) 閱讀:1133 作者:googlingman 欄目:開(kāi)發(fā)技術(shù)

1.簡(jiǎn)介

location是javascript里邊管理地址欄的內(nèi)置對(duì)象,比如location.href就管理頁(yè)面的url,用location.href=url就可以直接將頁(yè)面重定向url。而location.hash則可以用來(lái)獲取或設(shè)置頁(yè)面的標(biāo)簽值。比如http://domain/#admin的location.hash="#admin"。利用這個(gè)屬性值可以做一個(gè)非常有意義的事情。

 

2.window.location.href

 

取得當(dāng)前頁(yè)面的地址欄中字符串。

 

3.window.location.search

window.location.search方法是截取當(dāng)前url中“?”后面的字符串,例如:index.php?act=doctor,截取后的字符串就是act=doctor.

 

 

4.window.location.hash

 
很多人都喜歡收藏網(wǎng)頁(yè),以便于以后的瀏覽。不過(guò)對(duì)于Ajax頁(yè)面來(lái)說(shuō)的話,一般用一個(gè)頁(yè)面來(lái)處理所有的事務(wù),也就是說(shuō),如果你瀏覽到一個(gè)Ajax頁(yè)面里邊有意思的內(nèi)容,想將它收藏起來(lái),可是地址只有一個(gè)呀,下次你打開(kāi)這個(gè)地址,還是得像以往一樣不斷地去點(diǎn)擊網(wǎng)頁(yè),找到你鐘情的那個(gè)頁(yè)面。另外的話,瀏覽器上的“前進(jìn)”“后退”按鈕也會(huì)失效,這于很多習(xí)慣了傳統(tǒng)頁(yè)面的用戶來(lái)說(shuō),是一個(gè)很大的使用障礙。 


那么,怎么用location.hash來(lái)解決這兩個(gè)問(wèn)題呢?其實(shí)一點(diǎn)也不神秘。 


比如,我的作者管理系統(tǒng),主要功能有三個(gè):普通搜索、高級(jí)搜索、后臺(tái)管理,我分別給它們分配一個(gè)hash值:#search、#advsearch、#admin,在頁(yè)面初始化的時(shí)候,通過(guò)window.location.hash來(lái)判斷用戶需要訪問(wèn)的頁(yè)面,然后通過(guò)javascript來(lái)調(diào)整顯示頁(yè)面。比如: 


var hash; 
hash=(!window.location.hash)?"#search":window.location.hash; 
window.location.hash=hash; 
//調(diào)整地址欄地址,使前進(jìn)、后退按鈕能使用 
switch(hash){ 
case "#search": 
selectPanel("pnlSearch"); //顯示普通搜索面板 
break; 
case "#advsearch": 
case "#admin": 
}


通過(guò)window.location.hash=hash這個(gè)語(yǔ)句來(lái)調(diào)整地址欄的地址,使得瀏覽器里邊的“前進(jìn)”、“后退”按鈕能正常使用(實(shí)質(zhì)上欺騙了瀏覽器)。然后再根據(jù)hash值的不同來(lái)顯示不同的面板(用戶可以收藏對(duì)應(yīng)的面板了),這就使得Ajax頁(yè)面的瀏覽趨于傳統(tǒng)化了。

 

參考資源:

http://www.jb51.net/article/22656.htm

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI