自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

如何使用JavaScript解析URL

開發(fā) 前端
在 Web 開發(fā)中,有許多情況需要解析 URL,這篇主要學(xué)習(xí)如何使用 URL 對象實(shí)現(xiàn)這一點(diǎn)。

在 Web 開發(fā)中,有許多情況需要解析 URL,這篇主要學(xué)習(xí)如何使用 URL 對象實(shí)現(xiàn)這一點(diǎn)。

開始

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

  1. <html>  
  2.     <head>  
  3.         <title>JavaScript URL parsing</title>  
  4.     </head>  
  5.     <body>  
  6.         <script>  
  7.             // 激動人心的代碼即將寫在這里  
  8.         </script>  
  9.     </body>  
  10. </html> 

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

什么是 URL

這應(yīng)該是相當(dāng)簡單的,但讓我們說清楚。 URL 是網(wǎng)頁的地址,可以在瀏覽器中輸入以獲取該網(wǎng)頁的唯一內(nèi)容。 可以在地址欄中看到它:

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

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

URL 不都長的一樣的

這是一個(gè)快速提醒 - 有時(shí) 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

獲取當(dāng)前URL

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

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

  1. console.log(window.location); 

查看瀏覽器的控制臺:

不是你想要的?這是因?yàn)樗环祷啬阍跒g覽器中看到的實(shí)際 URL 地址——它返回的是一個(gè) URL 對象。使用這個(gè) URL 對象,我們可以解析 URL 的不同部分,接下來就會講到。

創(chuàng)建 URL 對象

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

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

就這么簡單! 可以打印 myURL 來查看 myURL 的內(nèi)容: 

  1. console.log(myURL); 

出于本文的目的,將 myURL 設(shè)置為這個(gè)值: 

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

將其復(fù)制并粘貼到 <script> 元素中,以便你可以繼續(xù)操作! 這個(gè) URL 的某些部分可能不熟悉,因?yàn)樗鼈儾⒉豢偸潜皇褂?- 但你將在下面了解它們,所以不要擔(dān)心!

URL 對象的結(jié)構(gòu)

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

href

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

  1. console.log(myURL.href);  
  2. // 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)。通常,網(wǎng)站將使用 HTTP 或 HTTPS。

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

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

主機(jī)名(hostname)

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

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

端口(port)

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

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

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

主機(jī)(host)

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

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

來源(origin)

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

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

pathname(文件名) 

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

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

錨點(diǎn)(hash)

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

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

查詢參數(shù) (search)

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

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

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

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

但是,如果我們想要拆分它們并獲取它們的值,那就有點(diǎn)復(fù)雜了。

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

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

  1. var searchParams = new URLSearchParams(myURL.search); 

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

  1. ?x=y&a=b 

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

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

擴(kuò)展

獲取 URL 的中參數(shù)

方法一:正則法 

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

方法二:split拆分法 

  1. function GetRequest() {  
  2.     var url = location.search; //獲取url中"?"符后的字串  
  3.     var theRequest = new Object();  
  4.     if (url.indexOf("?") != -1) {  
  5.         var str = url.substr(1);  
  6.         strstrs = str.split("&");  
  7.         for(var i = 0; i < strs.length; i ++) {  
  8.             theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);  
  9.         }  
  10.     }  
  11.     return theRequest;  
  12.  
  13. var Request = new Object();  
  14. Request = GetRequest();  
  15. // var 參數(shù)1,參數(shù)2,參數(shù)3,參數(shù)N;  
  16. // 參數(shù)1 = Request['參數(shù)1'];  
  17. // 參數(shù)2 = Request['參數(shù)2'];  
  18. // 參數(shù)3 = Request['參數(shù)3'];  
  19. // 參數(shù)N = Request['參數(shù)N']; 

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

  1. //替換指定傳入?yún)?shù)的值,paramName為參數(shù),replaceWith為新值  
  2. function replaceParamVal(paramName,replaceWith) {  
  3.     var oUrl = this.location.href.toString();  
  4.     var re=eval('/('+ paramName+'=)([^&]*)/gi');  
  5.     var nUrl = oUrl.replace(re,paramName+'='+replaceWith);  
  6.     this.location = nUrl 
  7.   window.location.href=nUrl  
責(zé)任編輯:龐桂玉 來源: segmenfault
相關(guān)推薦

2021-08-11 22:50:53

JavaScript編程開發(fā)

2016-11-14 19:45:39

JavaScript

2010-10-08 12:46:27

Javascriptreplace()

2018-02-23 11:11:11

PythonUrllibURL

2010-10-08 14:27:25

JavascriptSplit

2011-09-09 17:31:45

Android WebJavascript

2025-04-23 08:20:00

JavaScriptURLAPI

2011-09-13 09:49:59

PhoneGap插件

2019-05-28 10:24:31

V8JavaScript延遲

2021-05-28 09:10:40

JavaScript性能GPU

2024-09-27 09:12:12

JavaScriptscrollTo窗口

2009-01-19 09:40:53

JavaScript事件代理事件處理器

2023-02-01 14:08:53

JavaScriptURL安全

2022-02-11 19:08:07

JavaScriptURLurlcat

2010-03-15 10:49:57

Python函數(shù)變量

2009-06-10 21:51:42

JavaScript XMLFirefox

2017-09-12 15:11:12

Chrome

2022-06-07 08:00:00

JavaScript編程語言TSPL

2010-06-11 09:46:55

UML順序圖

2017-07-07 14:41:13

機(jī)器學(xué)習(xí)神經(jīng)網(wǎng)絡(luò)JavaScript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號