javascript中window.location.href的用法
一、前言
window.location.href
是一個(gè)用于獲取當(dāng)前頁(yè)面 URL 或讓瀏覽器跳轉(zhuǎn)到新 URL 的重要方法,是 window.location
對(duì)象的屬性。它返回一個(gè)字符串,表示當(dāng)前頁(yè)面的 URL;同時(shí),當(dāng)通過(guò)將 URL 指定給 window.location.href 時(shí),可以讓瀏覽器跳轉(zhuǎn)到新的 URL。
二、常見用例
- self.location.href="/url" 當(dāng)前頁(yè)面打開URL頁(yè)面
- location.href="/url :當(dāng)前頁(yè)面打開URL頁(yè)面
- window.location.href="/url" :當(dāng)前頁(yè)面打開URL頁(yè)面,前面三個(gè)用法相同。
- this.location.href="/url" :當(dāng)前頁(yè)面打開URL頁(yè)面
- parent.location.href="/url" :在父頁(yè)面打開新頁(yè)面
- top.location.href="/url" :在頂層頁(yè)面打開新頁(yè)面
- 如果頁(yè)面中自定義了 frame,那么可將parent self top換為自定義frame的名稱,效果是在frame窗口打開url地址
- window.location.href=window.location.href;和window.location.Reload() : 刷新當(dāng)前頁(yè)面。
區(qū)別在于是否有提交數(shù)據(jù)。
當(dāng)有提交數(shù)據(jù)時(shí),window.location.Reload()會(huì)提示是否提交,window.location.href=window.location.href;則是向指定的url提交數(shù)據(jù)
- 如果要關(guān)閉當(dāng)前窗口,并且在新窗口打開某一鏈接:
var a = document.createElement('a') a.setAttribute('href', href) a.setAttribute('target', '_blank') a.setAttribute('id', 'startTelMedicine') a.onclick = function () { //關(guān)閉窗口的方法 window.opener = null window.open('', '_self', '') window.close() } // 防止反復(fù)添加 if (document.getElementById('startTelMedicine')) { document.body.removeChild(document.getElementById('startTelMedicine')) } document.body.appendChild(a) a.click()
- 如果無(wú)法關(guān)閉當(dāng)前彈框 說(shuō)明可能有父節(jié)點(diǎn),可以試試:window.parent.close();
三、window.location.href和window.open的區(qū)別
1、window.location是window對(duì)象的屬性,而window.open是window對(duì)象的方法
window.location是你對(duì)當(dāng)前瀏覽器窗口的URL地址對(duì)象的參考!
window.open是用來(lái)打開一個(gè)新窗口的函數(shù)!
2、window.open不一定是打開一個(gè)新窗口!!!!!!!!
只要有窗口的名稱和window.open中第二個(gè)參數(shù)中的一樣就會(huì)將這個(gè)窗口替換,用這個(gè)特性的話可以在iframe和frame中來(lái)代替location.href。
如
<iframe name="aa"></iframe> <input type=button onclick="window.open('1.htm','aa','')">和 <input type=button onclick="self.frames['aa'].location.href='1.htm'">
的效果一樣
3、在給按鈕、表格、單元格、下拉列表和DIV等做鏈接時(shí)一般都要用Javascript來(lái)完成,和做普通鏈接一樣,可能我們需要讓鏈接頁(yè)面在當(dāng)前窗口打開,也可能需要在新窗口打開,這時(shí)我們就可以使用下面兩項(xiàng)之一來(lái)完成:
window.open 用來(lái)打開新窗口
window.location 用來(lái)替換當(dāng)前頁(yè),也就是重新定位當(dāng)前頁(yè)
可以用以下來(lái)個(gè)實(shí)例來(lái)測(cè)試一下。
<input type="button" value="新窗口打開" onclick="window.open('http://www.google.com')"> <input type="button" value="當(dāng)前頁(yè)打開" onclick="window.location='http://www.google.com/'">
4、window.location或window.open如何指定target?
這是一個(gè)經(jīng)常遇到的問(wèn)題,特別是在用frame框架的時(shí)候
解決辦法:
window.location 改為 top.location 即可在頂部鏈接到指定頁(yè)
或
window.open("你的網(wǎng)址","_top");
5、window.open 用來(lái)打開新窗口
window.location 用來(lái)替換當(dāng)前頁(yè),也就是重新定位當(dāng)前頁(yè)
用戶不能改變document.location(因?yàn)檫@是當(dāng)前顯示文檔的位置)。
window.location本身也是一個(gè)對(duì)象。
但是,可以用window.location改變當(dāng)前文檔 (用其它文檔取代當(dāng)前文檔),而document.location不是對(duì)象。
服務(wù)器重定向后有可能使document.url變動(dòng),但window.location.href指的永遠(yuǎn)是訪問(wèn)該網(wǎng)頁(yè)時(shí)用的URL.
大多數(shù)情況下,document.location和location.href是相同的,但是,當(dāng)存在服務(wù)器重定向時(shí),document.location包含的是已經(jīng)裝載的URL,而location.href包含的則是原始請(qǐng)求的文檔的URL.
6、window.open()是可以在一個(gè)網(wǎng)站上打開另外的一個(gè)網(wǎng)站的地址
window.location()是只能在一個(gè)網(wǎng)站中打開本網(wǎng)站的網(wǎng)頁(yè)
到此這篇關(guān)于javascript中window.location.href的用法 的文章就介紹到這了,更多相關(guān)javascript window.location.href內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- js中window.location.href的用法大全
- JavaScript Window 打開新窗口(window.location.href、window.open、window.showModalDialog)
- js獲取當(dāng)前頁(yè)的URL與window.location.href簡(jiǎn)單方法
- javascript 中設(shè)置window.location.href跳轉(zhuǎn)無(wú)效問(wèn)題解決辦法
- 快速解決js中window.location.href不工作的問(wèn)題
- 關(guān)于js中window.location.href,location.href,parent.location.href,top.location.href的用法與區(qū)別
相關(guān)文章
JavaScript 數(shù)組去重并統(tǒng)計(jì)重復(fù)元素出現(xiàn)的次數(shù)實(shí)例
下面小編就為大家分享一篇JavaScript 數(shù)組去重并統(tǒng)計(jì)重復(fù)元素出現(xiàn)的次數(shù)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2017-12-12js的.innerHTML = ""IE9下顯示有錯(cuò)誤的解決方法
js的.innerHTML= "……"在ie9- 的版本顯示不正常,使用jquery可以解決,有類似問(wèn)題的朋友可以參考下2013-09-09基于JavaScript實(shí)現(xiàn)評(píng)論框展開和隱藏功能
本文通過(guò)實(shí)例代碼給大家介紹了基于JavaScript實(shí)現(xiàn)評(píng)論框展開和隱藏功能,感興趣的朋友參考下吧2017-08-08JavaScript定時(shí)器實(shí)現(xiàn)的原理分析
JavaScript中的定時(shí)器大家基本在平時(shí)的開發(fā)中都遇見過(guò)吧,但是又有多少人去深入的理解其中的原理呢?本文我們就來(lái)分析一下定時(shí)器的實(shí)現(xiàn)原理、定時(shí)器的妙用、定時(shí)器使用注意事項(xiàng),有興趣的朋友可以看下2016-12-12js實(shí)現(xiàn)簡(jiǎn)單選項(xiàng)卡與自動(dòng)切換效果的方法
這篇文章主要介紹了js實(shí)現(xiàn)簡(jiǎn)單選項(xiàng)卡與自動(dòng)切換效果的方法,涉及javascript操作選項(xiàng)卡與自動(dòng)切換效果的實(shí)現(xiàn)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04JavaScript實(shí)現(xiàn)左右下拉框動(dòng)態(tài)增刪示例
本篇文章主要介紹了JavaScript實(shí)現(xiàn)左右下拉框動(dòng)態(tài)增刪示例,可以對(duì)下拉框進(jìn)行刪除和增加,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-03-03基于JS代碼實(shí)現(xiàn)簡(jiǎn)單易用的倒計(jì)時(shí) x 天 x 時(shí) x 分 x 秒效果
這篇文章主要介紹了基于JS代碼實(shí)現(xiàn)簡(jiǎn)單易用的倒計(jì)時(shí) x 天 x 時(shí) x 分 x 秒效果,需要的朋友可以參考下2017-07-07