亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript獲取當前頁面路徑的三種方法

 更新時間:2024年05月17日 11:33:59   作者:sg_knight  
在Web開發(fā)中,我們經(jīng)常需要獲取當前頁面的URL路徑,以便進行導航、數(shù)據(jù)加載或其他與頁面相關(guān)的操作,JavaScript提供了幾種方法來幫助我們實現(xiàn)這一功能,在本文中,我們將探討幾種常用的方法,需要的朋友可以參考下

引言

在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)文章

最新評論