成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

使用JavaScript解析URL的方法示例

前言

創(chuàng)新互聯(lián)公司是一家專業(yè)提供北京企業(yè)網站建設,專注與成都做網站、網站制作、H5開發(fā)、小程序制作等業(yè)務。10年已為北京眾多企業(yè)、政府機構等服務。創(chuàng)新互聯(lián)專業(yè)網站設計公司優(yōu)惠進行中。

在 Web 開發(fā)中,有許多情況需要解析 URL,這篇主要學習如何使用 URL 對象實現(xiàn)這一點。下面話不多說了,來一起看看詳細的介紹吧

開始

創(chuàng)建一個以下內容的 HTML 文件,并在瀏覽器中打開。

<html>
 <head>
 <title>JavaScript URL parsing</title>
 </head>
 <body>
 <script>
  // 激動人心的代碼即將寫在這里
 </script>
 </body>
</html>

如果你想嘗試本文中的任何內容,可以將其放在 <script> 標記中,保存,重新加載頁面,看看會發(fā)生什么! 在本教程中,將使用 console.log 來打印所需要的內容,你可以打開開發(fā)都工具,來查看內容。

什么是 URL

這應該是相當簡單的,但讓我們說清楚。 URL 是網頁的地址,可以在瀏覽器中輸入以獲取該網頁的唯一內容。 可以在地址欄中看到它:

使用JavaScript解析URL的方法示例

URL 是統(tǒng)一資源定位符,對可以從互聯(lián)網上得到的資源的位置和訪問方法的一種簡潔的表示,是互聯(lián)網上標準資源的地址?;ヂ?lián)網上的每個文件都有一個唯一的 URL,它包含的信息指出文件的位置以及瀏覽器應該怎么處理它。

此外,如果你不熟悉基本 URL 路徑的工作方式,可以查看此文學習。

URL 不都長的一樣的

這是一個快速提醒 - 有時 URL 可能非常奇怪,如下:

https://example.com:1234/page/?a=b

http://localhost/page.html

https://154.23.54.156/page?x=...

file:///Users/username/folder/file.png

獲取當前URL

獲取當前頁面的 URL 非常簡單 - 我們可以使用 window.location。

試著把這個添加到我們形如寫的的腳本中:

console.log(window.location);

查看瀏覽器的控制臺:

使用JavaScript解析URL的方法示例

不是你想要的?這是因為它不返回你在瀏覽器中看到的實際 URL 地址——它返回的是一個 URL 對象。使用這個 URL 對象,我們可以解析 URL 的不同部分,接下來就會講到。

創(chuàng)建 URL 對象

很快就會看到,可以使用 URL 對象來了解 URL 的不同部分。如果你想對任何 URL 執(zhí)行此操作,而不僅僅是當前頁面的 URL,該怎么辦? 我們可以通過創(chuàng)建一個新的 URL 對象來實現(xiàn)。 以下是如何創(chuàng)建一個:

var myURL = new URL('https://example.com');

就這么簡單! 可以打印 myURL 來查看 myURL 的內容:

console.log(myURL);

使用JavaScript解析URL的方法示例

出于本文的目的,將 myURL 設置為這個值:

var myURL = new URL('https://example.com:4000/folder/page.html?x=y&a=b#section-2')

將其復制并粘貼到 <script> 元素中,以便你可以繼續(xù)操作! 這個 URL 的某些部分可能不熟悉,因為它們并不總是被使用 - 但你將在下面了解它們,所以不要擔心!

URL 對象的結構

使用 URL 對象,可以非常輕松地獲取 URL 的不同部分。 以下是你可以從 URL 對象獲得的所有內容。 對于這些示例,我們將使用上面設置的 myURL。

href

URL 的 href 基本上是作為字符串(文本)的整個 URL。如果你想把頁面的 URL 作為字符串而不是 URL 對象,你可以寫 window.location.href。

console.log(myURL.href);
// Output: https://example.com:4000/folder/page.html?x=y&a=b#section-2

協(xié)議 (protocol)

URL的協(xié)議是一開始的部分。這告訴瀏覽器如何訪問該頁面,例如通過 HTTP 或 HTTPS。 但是還有很多其他協(xié)議,比如 ftp(文件傳輸協(xié)議)和 ws(WebSocket)。通常,網站將使用 HTTP 或 HTTPS。

雖然如果你的計算機上打開了文件,你可能正在使用文件協(xié)議! URL對象的協(xié)議部分包括:,但不包括 //。 讓我們看看 myURL 吧!

console.log(myURL.protocol);
// Output: "https:"

主機名(hostname)

主機名是站點的域名。 如果你不熟悉域名,則它是在瀏覽器中看到的URL的主要部分 - 例如 google.com 或codetheweb.blog。

console.log(myURL.hostname);
// Output: "example.com"

端口(port)

URL 的端口號位于域名后面,用冒號分隔(例如 example.com:1234)。 大多數(shù)網址都沒有端口號,這種情況非常罕見。

端口號是服務器上用于獲取數(shù)據(jù)的特定“通道” - 因此,如果我擁有 example.com,我可以在多個不同的端口上發(fā)送不同的數(shù)據(jù)。 但通常域名默認為一個特定端口,因此不需要端口號。 來看看 myURL 的端口號:

console.log(myURL.port);
// Output: "4000"

主機(host)

主機只是主機名和端口放在一起,嘗試獲取 myURL 的主機:

console.log(myURL.host);
// Output: "example.com:4000"

來源(origin)

origin 由 URL 的協(xié)議,主機名和端口組成。 它基本上是整個 URL,直到端口號結束,如果沒有端口號,到主機名結束。

console.log(myURL.origin);
// Output: https://example.com:4000

pathname(文件名)

pathname 從域名的最后一個 “/” 開始到 “?” 為止,是文件名部分,如果沒有 “?” ,則是從域名最后的一個 “/” 開始到 “#” 為止 , 是文件部分, 如果沒有 “?” 和 “#” , 那么從域名后的最后一個 “/” 開始到結束 , 都是文件名部分。

console.log(myURL.pathname);
// Output: "/folder/page.html"

錨點(hash)

從 “#” 開始到最后,都是錨部分??梢詫⒐V堤砑拥?URL 以直接滾動到具有 ID 為該值的哈希值 的元素。 例如,如果你有一個 id 為 hello 的元素,則可以在 URL 中添加 #hello 就可以直接滾動到這個元素的位置上。通過以下方式可以在 URL 獲取 “#” 后面的值:

console.log(myURL.hash);
// Output: "#section-2"

查詢參數(shù) (search)

你還可以向 URL 添加查詢參數(shù)。它們是鍵值對,意味著將特定的“變量”設置為特定值。 查詢參數(shù)的形式為 key=value。 以下是一些 URL 查詢參數(shù)的示例:

?key1=value1&key2=value2&key3=value3

請注意,如果 URL 也有 錨點(hash),則查詢參數(shù)位于 錨點(hash)(也就是 ‘#')之前,如我們的示例 URL 中所示:

console.log(myURL.search);
// Output: "?x=y&a=b"

但是,如果我們想要拆分它們并獲取它們的值,那就有點復雜了。

使用 URLSearchParams 解析查詢參數(shù)

要解析查詢參數(shù),我們需要創(chuàng)建一個 URLSearchParams 對象,如下所示:

var searchParams = new URLSearchParams(myURL.search);

然后可以通過調用 searchParams.get('key')來獲取特定鍵的值。 使用我們的示例網址 - 這是原始搜索參數(shù):

?x=y&a=b

因此,如果我們調用 searchParams.get('x'),那么它應該返回 y,而 searchParams.get('a')應該返回 b,我們來試試吧!

console.log(searchParams.get('x'));
// Output: "y"
console.log(searchParams.get('a'));
// Output: "b"

擴展

獲取 URL 的中參數(shù)

方法一:正則法

function getQueryString(name) {
 var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
 var r = window.location.search.substr(1).match(reg);
 if (r != null) {
 return unescape(r[2]);
 }
 return null;
}
// 這樣調用:
alert(GetQueryString("參數(shù)名1"));
alert(GetQueryString("參數(shù)名2"));

alert(GetQueryString("參數(shù)名3"));

方法二:split拆分法

function GetRequest() {
 var url = location.search; //獲取url中"?"符后的字串
 var theRequest = new Object();
 if (url.indexOf("?") != -1) {
 var str = url.substr(1);
 strs = str.split("&");
 for(var i = 0; i < strs.length; i ++) {
  theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
 }
 }
 return theRequest;
}
var Request = new Object();
Request = GetRequest();
// var 參數(shù)1,參數(shù)2,參數(shù)3,參數(shù)N;
// 參數(shù)1 = Request['參數(shù)1'];
// 參數(shù)2 = Request['參數(shù)2'];
// 參數(shù)3 = Request['參數(shù)3'];
// 參數(shù)N = Request['參數(shù)N'];

修改 URL 的中某個參數(shù)值

//替換指定傳入參數(shù)的值,paramName為參數(shù),replaceWith為新值
function replaceParamVal(paramName,replaceWith) {
 var oUrl = this.location.href.toString();
 var re=eval('/('+ paramName+'=)([^&]*)/gi');
 var nUrl = oUrl.replace(re,paramName+'='+replaceWith);
 this.location = nUrl;
  window.location.href=nUrl
}

原文:https://codetheweb.blog/2019/01/21/javascript-url-parsing/

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對創(chuàng)新互聯(lián)的支持。

本文標題:使用JavaScript解析URL的方法示例
當前地址:http://jinyejixie.com/article10/iicsgo.html

成都網站建設公司_創(chuàng)新互聯(lián),為您提供云服務器標簽優(yōu)化、網站導航、軟件開發(fā)網頁設計公司、域名注冊

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

成都網站建設
上杭县| 揭东县| 北海市| 宁强县| 蓝山县| 梧州市| 工布江达县| 姚安县| 金昌市| 平武县| 齐河县| 沂源县| 呼和浩特市| 昌江| 宜都市| 东至县| 耿马| 纳雍县| 吉林市| 名山县| 临城县| 井冈山市| 嵊州市| 丰城市| 修文县| 泽州县| 南平市| 韩城市| 壶关县| 绥棱县| 台前县| 榕江县| 莫力| 沾益县| 噶尔县| 贺州市| 江川县| 柳州市| 来凤县| 固始县| 芜湖县|