JavaScript獲取當前頁面路徑的三種方法
引言
在Web開發(fā)中,我們經(jīng)常需要獲取當前頁面的URL路徑,以便進行導航、數(shù)據(jù)加載或其他與頁面相關(guān)的操作。JavaScript提供了幾種方法來幫助我們實現(xiàn)這一功能。在本文中,我們將探討幾種常用的方法。
方法一:使用 window.location 對象
window.location
對象包含了關(guān)于當前URL的詳細信息。你可以通過訪問其屬性來獲取URL的不同部分。
// 獲取完整的URL var fullUrl = window.location.href; console.log(fullUrl); // 輸出完整的URL,例如:https://example.com/page/index.html?param=value#section // 獲取路徑部分(不包括域名和查詢字符串) var pathname = window.location.pathname; console.log(pathname); // 輸出路徑部分,例如:/page/index.html // 獲取查詢字符串部分(包括問號) var search = window.location.search; console.log(search); // 輸出查詢字符串部分,例如:?param=value // 獲取哈希部分(包括井號) var hash = window.location.hash; console.log(hash); // 輸出哈希部分,例如:#section
方法二:使用 document.URL
document.URL
屬性也是一個簡單的選擇,它直接返回完整的URL。
var fullUrl = document.URL; console.log(fullUrl); // 輸出完整的URL,與window.location.href相同
方法三:使用 new URL() 構(gòu)造函數(shù)
在現(xiàn)代瀏覽器中,URL
構(gòu)造函數(shù)提供了更強大的URL解析和操作能力。通過它,你可以更細致地獲取URL的各個部分,并對其進行修改。
var urlObject = new URL(window.location.href); // 獲取協(xié)議(例如:"https:") var protocol = urlObject.protocol; console.log(protocol); // 輸出協(xié)議,例如:https: // 獲取主機名(例如:"www.example.com") var hostname = urlObject.hostname; console.log(hostname); // 輸出主機名 // 獲取端口號(如果有的話) var port = urlObject.port; console.log(port); // 輸出端口號,默認為空字符串(如果使用的是默認端口) // 獲取路徑名(與window.location.pathname相同) var pathname = urlObject.pathname; console.log(pathname); // 輸出路徑名 // 獲取搜索參數(shù)(作為URLSearchParams對象) var searchParams = urlObject.searchParams; console.log(searchParams.get('param')); // 輸出查詢字符串中名為'param'的參數(shù)值 // 獲取哈希(與window.location.hash相同,但不包括井號) var hashWithoutPound = urlObject.hash.slice(1); // 移除井號 console.log(hashWithoutPound); // 輸出哈希部分,例如:section
拓展知識:Javascript 獲取url路徑中的參數(shù)
需求
假設(shè)騎在路徑:https://localhost/zhaopin?name=aa&age=18&state=2
,現(xiàn)在要獲取url中各參數(shù)的值,比如:當請求name時獲取到aa,當獲取到age時獲取到18。
理論基礎(chǔ)
let url = document.location.toString();//獲取url地址 let urlParmStr = url.slice(url.indexOf('?')+1);//獲取問號后所有的字符串 let arr = urlParmStr.split('&');//通過&符號將字符串分割轉(zhuǎn)成數(shù)組 let courseId = arr[0].split("=")[1];//獲取數(shù)組中第一個參數(shù) let unit_title=arr[1].split("=")[1];//第二個參數(shù) unit_title=decodeURI(unit_title);//轉(zhuǎn)碼將解碼方式unscape換為decodeURI,將中文參數(shù)獲取 console.log(unit_title);
解決方案
方法一:
function getUrlVariable(variable) { var query = window.location.search.substring(1); var vars = query.split("&"); for (var i = 0; i < vars.length; i++) { var pair = vars[i].split("="); if (pair[0] == variable) { return pair[1]; } } //返回boolean類型的數(shù)據(jù) return (false); }
方法二:
function getUrlParameter(name) { name = name.replace(/[]/, "\[").replace(/[]/, "\[").replace(/[]/, "\\\]"); var regexS = "[\\?&]" + name + "=([^&#]*)"; var regex = new RegExp(regexS); var results = regex.exec(window.parent.location.href); if (results == null) return ""; else { return results[1]; } }
測試
測試路徑:https://localhost/zhaopin?name=aa&age=18&state=2
<script> let name =getUrlVariable("name"); console.log(name); </script>
總結(jié)
以上就是在JavaScript中獲取當前頁面路徑的幾種常用方法。每種方法都有其獨特的用途和優(yōu)點,你可以根據(jù)具體需求選擇適合你的方法。無論你選擇哪種方法,都能輕松地獲取到當前頁面的路徑并進行相應的操作。
在大多數(shù)情況下,使用 window.location 或 document.URL 就足夠了,但如果你需要更復雜的URL處理或修改,那么 URL 構(gòu)造函數(shù)將是一個更好的選擇。
到此這篇關(guān)于JavaScript獲取當前頁面路徑的三種方法的文章就介紹到這了,更多相關(guān)JavaScript獲取頁面路徑內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
十個開發(fā)人員面臨的最常見的JavaScript問題總結(jié)
今天,JavaScript?是幾乎所有現(xiàn)代?Web?應用的核心。這就是為什么JavaScript問題,以及找到導致這些問題的錯誤,是?Web?發(fā)者的首要任務。本文總結(jié)了十個常見的問題及解決方法,需要的可以參考一下2022-11-11微信小程序網(wǎng)絡(luò)數(shù)據(jù)請求服務實現(xiàn)詳解
這篇文章主要介紹了微信小程序網(wǎng)絡(luò)數(shù)據(jù)請求服務,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧2022-10-10JavaScript數(shù)組,JSON對象實現(xiàn)動態(tài)添加、修改、刪除功能示例
這篇文章主要介紹了JavaScript數(shù)組,JSON對象實現(xiàn)動態(tài)添加、修改、刪除功能,結(jié)合實例形式分析了JavaScript針對json數(shù)組的添加、刪除、修改操作實現(xiàn)技巧,需要的朋友可以參考下2018-05-05