精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

如何使用JavaScript解析URL

開發 前端
在 Web 開發中,有許多情況需要解析 URL,這篇主要學習如何使用 URL 對象實現這一點。

在 Web 開發中,有許多情況需要解析 URL,這篇主要學習如何使用 URL 對象實現這一點。

開始

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

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

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

什么是 URL

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

URL 是統一資源定位符,對可以從互聯網上得到的資源的位置和訪問方法的一種簡潔的表示,是互聯網上標準資源的地址。互聯網上的每個文件都有一個唯一的 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。

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

  1. console.log(window.location); 

查看瀏覽器的控制臺:

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

創建 URL 對象

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

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

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

  1. console.log(myURL); 

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

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

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

URL 對象的結構

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

href

URL 的 href 基本上是作為字符串(文本)的整個 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" 

協議 (protocol)

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

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

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

主機名(hostname)

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

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

端口(port)

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

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

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

主機(host)

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

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

來源(origin)

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

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

pathname(文件名) 

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

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

錨點(hash)

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

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

查詢參數 (search)

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

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

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

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

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

使用 URLSearchParams 解析查詢參數

要解析查詢參數,我們需要創建一個 URLSearchParams 對象,如下所示: 

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

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

  1. ?x=y&a=b 

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

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

擴展

獲取 URL 的中參數

方法一:正則法 

  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. // 這樣調用:  
  10. alert(GetQueryString("參數名1"));  
  11. alert(GetQueryString("參數名2"));  
  12. alert(GetQueryString("參數名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 參數1,參數2,參數3,參數N;  
  16. // 參數1 = Request['參數1'];  
  17. // 參數2 = Request['參數2'];  
  18. // 參數3 = Request['參數3'];  
  19. // 參數N = Request['參數N']; 

修改 URL 的中某個參數值 

  1. //替換指定傳入參數的值,paramName為參數,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  
責任編輯:龐桂玉 來源: segmenfault
相關推薦

2021-08-11 22:50:53

JavaScript編程開發

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延遲

2024-09-27 09:12:12

JavaScriptscrollTo窗口

2021-05-28 09:10:40

JavaScript性能GPU

2009-01-19 09:40:53

JavaScript事件代理事件處理器

2010-03-15 10:49:57

Python函數變量

2022-02-11 19:08:07

JavaScriptURLurlcat

2023-02-01 14:08:53

JavaScriptURL安全

2017-09-12 15:11:12

Chrome

2022-06-07 08:00:00

JavaScript編程語言TSPL

2009-06-10 21:51:42

JavaScript XMLFirefox

2023-05-11 08:00:00

JavaScript柱狀圖

2017-07-07 14:41:13

機器學習神經網絡JavaScript
點贊
收藏

51CTO技術棧公眾號

久久电影天堂| 黄色av网址在线| 成人影院天天5g天天爽无毒影院| 欧美午夜不卡在线观看免费| 日韩高清专区| 国产情侣在线播放| 国产一区二区精品| 日韩中文字幕在线| 69久久精品无码一区二区| 欧美激情网站| 18成人在线视频| 久久国产精品一区二区三区四区| 亚洲一区中文字幕永久在线| 国产精品草草| 色偷偷噜噜噜亚洲男人| 国产精品伦子伦| 亚洲日本免费电影| 欧美视频在线观看免费网址| 一区二区三区四区视频在线观看| 日日躁夜夜躁白天躁晚上躁91| 蜜臀av一区二区在线免费观看 | 成人一级片免费看| 日韩成人综合网| 在线免费不卡视频| 国产午夜福利在线播放| 1区2区在线观看| 91免费看`日韩一区二区| 亚洲一区国产精品| 午夜视频网站在线观看| 99精品视频免费观看视频| 久久久国产精品亚洲一区| 一级黄色片大全| 精品深夜福利视频| 精品少妇一区二区三区在线视频| 天天爽夜夜爽一区二区三区| 欧洲av不卡| 精品美女国产在线| 成人性免费视频| 羞羞视频在线观看不卡| 日韩理论在线观看| 亚洲黄色成人久久久| 神马久久久久| 99久久精品免费看国产| 国产91色在线|亚洲| 国产aⅴ一区二区三区| 久久精品国产亚洲a| 国产精品久久久久久久7电影| 国产精品免费精品一区| 丁香在线视频| 视频一区日韩精品| 欧美日韩精品一区二区三区四区| www.日本在线播放| 欧美性xxxx极品hd满灌| 日本久久久久久久久| 日本少妇毛茸茸高潮| 欧美日韩精品免费观看视频完整| 久久精品福利视频| 成人免费视频国产免费观看| 91精品国产调教在线观看| 久久久国产视频| 国产十六处破外女视频| 欧美久久一级| 韩国欧美亚洲国产| 狠狠躁夜夜躁人人爽天天高潮| 你懂的成人av| 久久免费观看视频| 国产成人免费看| 久久久久综合| 国产美女扒开尿口久久久| 国产孕妇孕交大片孕| 国产精品亚洲一区二区三区在线 | 日韩视频免费在线观看| 99精品中文字幕| 91精品久久久久久久久久不卡| 久久精品国产欧美激情| 久久久精品99| 亚洲在线播放| 国产综合久久久久久| 国产草草影院ccyycom| 成人在线综合网站| 欧美日韩在线观看一区| 欧美三级电影一区二区三区| 亚洲激情综合网| 成人黄色大片网站| 日韩高清成人| 日韩视频免费观看高清完整版在线观看 | 日韩欧美国产成人一区二区| 蜜臀视频在线观看| 狠狠做六月爱婷婷综合aⅴ| www.日韩av.com| 国产无精乱码一区二区三区| 每日更新成人在线视频| 91精品视频在线看| 日韩porn| 亚洲精品视频观看| 日av中文字幕| 一区二区日韩| 亚洲一区二区精品| 久久久久成人精品无码| 日韩av一二三| 国产亚洲欧美一区二区 | 久久91精品国产91久久跳| 草久久免费视频| 国内成人精品2018免费看| 蜜桃传媒视频麻豆一区| 怡红院红怡院欧美aⅴ怡春院| 高跟丝袜欧美一区| 免费欧美一级片| 欧美日韩精品在线一区| 韩剧1988免费观看全集| 一级特黄特色的免费大片视频| 成人福利电影精品一区二区在线观看| 日本一区二区三区www| 俺来也官网欧美久久精品| 欧美色图第一页| 日本xxx在线播放| 午夜精品视频| 国产一区深夜福利| 激情小视频在线| 亚洲国产成人va在线观看天堂| 色播五月综合网| 久久综合色占| 8x拔播拔播x8国产精品| 肥臀熟女一区二区三区| 亚洲欧美视频一区| 人人干人人干人人| 精品72久久久久中文字幕| 97在线看福利| 亚洲风情第一页| 亚洲日本青草视频在线怡红院| 99视频精品免费| 一区二区三区四区在线看 | 成人免费在线观看视频| 亚洲精品综合久久中文字幕| 国产亚洲精品久久久久久无几年桃 | 成人久久精品人妻一区二区三区| 中文字幕在线一区免费| www亚洲成人| 欧美日韩一二三四| 国产成人av在线播放| 视频福利在线| 色一情一乱一乱一91av| 亚洲婷婷在线观看| 黄色免费成人| 国产伦精品一区二区三区四区免费| av在线免费播放| 日韩一区二区三| 欧美黄色免费在线观看| 国产成人精品一区二区三区网站观看| 中文字幕免费高| 国产精品99久久免费| 久久综合久久88| 国产免费福利视频| 亚洲女人小视频在线观看| 亚洲成人av免费观看| 亚洲国产精品久久久天堂| 亚洲自拍另类欧美丝袜| 女同一区二区免费aⅴ| 精品国产乱码久久| 日韩激情在线播放| 久久欧美一区二区| 国产91色在线观看| 五月综合激情| 成人一区二区在线| 天堂中文在线播放| 一区二区三区无码高清视频| 一本色道久久综合无码人妻| 亚洲欧美日韩精品久久久久| 美女日批在线观看| 一级黄色片毛片| 91九色在线看| 精品国产乱码久久| 国产成人无码一区二区三区在线| 不卡视频一二三四| 久久久噜噜噜www成人网| 国产伦精品一区二区三区视频 | 国产精品suv一区二区69| 91在线观看免费视频| 日本成人在线免费视频| 国产精品久久久久久久免费观看 | 亚洲同性gay激情无套| 在线观看免费视频黄| 六月婷婷一区| 日本免费在线视频观看| 国产精品中文字幕制服诱惑| 国产99久久精品一区二区永久免费 | 1pondo在线播放免费| 日韩亚洲欧美综合| 99久热在线精品996热是什么| 国产精品免费视频一区| 亚洲美女精品视频| 日韩国产欧美在线播放| 久久久久久久久网| 精品一区三区| 97免费资源站| 国产私拍福利精品视频二区| 九九热视频这里只有精品| 色哟哟中文字幕| 欧美二区三区91| 影音先锋在线国产| 亚洲精品久久久久久国产精华液| 成人乱码一区二区三区av| 国产一区二区三区在线观看免费视频| 免费在线观看亚洲视频| 天天综合国产| 欧美一区二区三区在线播放| 免费欧美网站| 国产精品久久久| 超碰在线视屏| 欧美大学生性色视频| 97在线观看免费观看高清 | 在线亚洲观看| 玖玖精品在线视频| 日本大胆欧美| 欧洲亚洲一区二区| 美女视频亚洲色图| 不卡视频一区二区三区| 日本久久一区| 国产精品福利在线观看| 在线观看涩涩| 午夜精品久久17c| 曰本三级在线| 久久影视电视剧免费网站| yiren22综合网成人| 日韩精品极品毛片系列视频| 欧美 日韩 综合| 欧美一区二区三区在线电影| 亚洲一区二区激情| 在线看日韩精品电影| 人妻 日韩精品 中文字幕| 亚洲va在线va天堂| 久青草视频在线观看| 亚洲欧美日韩一区| 唐朝av高清盛宴| 日韩一区在线免费观看| 四虎地址8848| 中文字幕中文字幕一区| 亚洲女人毛茸茸高潮| 中文字幕欧美国产| 九九热免费在线| 国产欧美一区二区精品久导航| 色无极影院亚洲| 久久综合99re88久久爱| 中文字幕国产综合| 久久久99精品久久| 亚洲a v网站| 欧美国产日韩在线观看| 欧美 日韩 成人| 日本一区二区不卡视频| 特级西西人体高清大胆| 国产精品免费网站在线观看| 欧美特黄一级片| 亚洲男人的天堂在线aⅴ视频| 亚洲视频重口味| 亚洲精品日日夜夜| 国产亚洲精品久久久久久打不开| 亚洲国产日韩精品| 久久亚洲精品国产| 色婷婷av一区二区三区软件| 久久午夜鲁丝片| 777亚洲妇女| 午夜精品一二三区| 亚洲级视频在线观看免费1级| 亚欧洲精品视频| 亚洲欧洲中文天堂| 欧美18一19xxx性| 欧美激情女人20p| 中文字幕乱码中文乱码51精品| 日本一区二区不卡| 欧美91在线|欧美| 91传媒在线免费观看| 好吊妞国产欧美日韩免费观看网站 | 日本黄色三级大片| 麻豆91小视频| 亚洲成人福利视频| 久久综合色之久久综合| 精品国产大片大片大片| 亚洲成人精品在线观看| 一级一片免费看| 91精品视频网| 性感美女视频一二三| 日韩一区二区三区在线播放| 麻豆av在线免费观看| 欧美综合第一页| 亚洲爽爆av| 精品久久精品久久| 91欧美大片| 99精品在线免费视频| 久久99国产精品久久99果冻传媒| 人妻 丝袜美腿 中文字幕| 久久久久国产精品人| 四虎免费在线视频| 在线观看区一区二| 亚洲狼人综合网| 一本久久综合亚洲鲁鲁| 岛国毛片av在线| 国产精品日韩在线观看| 国产日韩三级| 一区中文字幕在线观看| 久久不射网站| 亚洲熟妇一区二区| 国产精品久久久久久久久免费相片| 久久久久无码精品国产| 欧美日韩一区在线| 日韩欧美电影在线观看| 久久国产天堂福利天堂| 精品欧美日韩精品| 精品国产乱码久久久久久蜜柚| 欧美肥老太太性生活| 日本三级免费观看| 成人毛片在线观看| www.毛片com| 欧美日韩一区 二区 三区 久久精品| 色呦呦中文字幕| 欧美放荡办公室videos4k| 欧美xxxx网站| 日产国产精品精品a∨| 99av国产精品欲麻豆| 曰本三级日本三级日本三级| 国产精品不卡在线| 中文字幕理论片| 亚洲欧美在线免费观看| 操人在线观看| 国产女人水真多18毛片18精品| 亚洲欧美网站在线观看| 青青草精品视频在线观看| 91热门视频在线观看| 在线免费观看毛片| 欧美不卡在线视频| 岛国成人毛片| 成人夜晚看av| 99精品在线观看| 在线观看免费视频高清游戏推荐| 国产日韩成人精品| www.com亚洲| 亚洲精品一区二区三区不| 黄视频网站在线观看| 国产日韩欧美二区| 亚洲国产网站| 小毛片在线观看| 午夜精品久久久久久久| 免费国产精品视频| 国内精品模特av私拍在线观看| 超碰在线亚洲| 国产69精品久久久久999小说| 国产成人精品网址| 久青草免费视频| 亚洲黄色av女优在线观看 | 狠狠色丁香久久综合频道| aaaaa黄色片| 亚洲五码中文字幕| 日本激情一区二区| 26uuu国产精品视频| 免费久久久久久久久| 噼里啪啦国语在线观看免费版高清版| 国产视频一区二区在线| 亚洲天堂999| 久久激情五月丁香伊人| 久久伊人影院| 美女扒开大腿让男人桶| 9人人澡人人爽人人精品| 国产成人精品网| 中文字幕九色91在线| 成人黄色理论片| 久久国产精品网| 久久色成人在线| 在线观看免费视频a| 欧美成人精品h版在线观看| 97久久亚洲| 欧美日韩第二页| 国产精品区一区二区三| 国产高清免费av| 欧美一区二区三区艳史| 日韩电影免费网址| 久久发布国产伦子伦精品| 精品电影在线观看| 91大神在线网站| 不卡视频一区二区三区| 午夜在线a亚洲v天堂网2018| 伊人影院综合网| 精品久久免费看| 性欧美gay| av 日韩 人妻 黑人 综合 无码| 99久久亚洲一区二区三区青草| 性高潮视频在线观看| 欧美国产日韩二区| 欧洲grand老妇人| 亚洲妇女无套内射精| 在线观看91视频| 韩国日本一区| 亚洲欧洲日韩精品| caoporn国产一区二区| 在线观看免费中文字幕| 97免费中文视频在线观看| 色爱综合网欧美| 国产 中文 字幕 日韩 在线| 欧美欧美欧美欧美首页| 日韩伦理在线一区| 日韩视频一二三| 欧美韩国日本不卡|