亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

使用JavaScript解析URL的方法示例

2024-05-06 16:48:37
字體:
來源:轉載
供稿:網友

前言

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

開始

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

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

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

什么是 URL

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

JavaScript,解析,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。

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

console.log(window.location);

查看瀏覽器的控制臺:

JavaScript,解析,URL

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

創建 URL 對象

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

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> 元素中,以便你可以繼續操作! 這個 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

協議 (protocol)

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

雖然如果你的計算機上打開了文件,你可能正在使用文件協議! URL對象的協議部分包括:,但不包括 //。 讓我們看看 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)。 大多數網址都沒有端口號,這種情況非常罕見。

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

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

主機(host)

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

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

來源(origin)

origin 由 URL 的協議,主機名和端口組成。 它基本上是整個 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"

查詢參數 (search)

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

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

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

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

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

使用 URLSearchParams 解析查詢參數

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

var searchParams = new URLSearchParams(myURL.search);

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

?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 的中參數

方法一:正則法

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("參數名1"));alert(GetQueryString("參數名2"));alert(GetQueryString("參數名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 參數1,參數2,參數3,參數N;// 參數1 = Request['參數1'];// 參數2 = Request['參數2'];// 參數3 = Request['參數3'];// 參數N = Request['參數N'];

修改 URL 的中某個參數值

//替換指定傳入參數的值,paramName為參數,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/

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美在线视频a| 亚洲精品国产精品久久清纯直播| 国产欧美日韩精品丝袜高跟鞋| 成人激情综合网| 日韩风俗一区 二区| 日韩av观看网址| 日韩av男人的天堂| 久久精品国产欧美亚洲人人爽| 懂色av中文一区二区三区天美| 91国内免费在线视频| 国产精品高潮视频| 国产一区二区三区免费视频| 色爱av美腿丝袜综合粉嫩av| 亚洲一二三在线| www日韩欧美| 国产精品日韩一区| 亚洲xxxx视频| 日韩av电影在线免费播放| 亚洲色图国产精品| 成人乱色短篇合集| 91精品久久久久久久久久久久久| 日本中文字幕久久看| 亚洲片av在线| 57pao国产精品一区| 日韩av在线免费观看一区| 精品香蕉在线观看视频一| 久久亚洲精品一区| 色偷偷888欧美精品久久久| 国产原创欧美精品| 91av国产在线| 亚洲一区中文字幕| 国产在线观看一区二区三区| 欧美国产欧美亚洲国产日韩mv天天看完整| 欧美激情中文字幕乱码免费| 欧美激情一二三| 岛国av午夜精品| 亚洲久久久久久久久久| 亚洲社区在线观看| 亚洲性夜色噜噜噜7777| 欧美在线观看www| 国外视频精品毛片| 欧美日韩xxxxx| 日韩专区中文字幕| 久久久国产成人精品| 国产成人av在线播放| 91成人精品网站| 国产在线观看精品| 亚洲欧美日韩久久久久久| 国产亚洲综合久久| 成人福利网站在线观看11| 国产精品h在线观看| 夜色77av精品影院| 国产成人精品视频在线观看| 欧美专区在线播放| 亚洲第一综合天堂另类专| 日本精品久久中文字幕佐佐木| 2019中文字幕免费视频| 最近中文字幕日韩精品| 国产成人一区二区三区电影| 日本成人激情视频| 亚洲欧美日韩在线一区| 色综合久久天天综线观看| 8x海外华人永久免费日韩内陆视频| 精品久久久久久久久久久久久| 欧美成aaa人片在线观看蜜臀| 亚洲精品av在线| 国产精品91在线观看| 狠狠色狠狠色综合日日五| 欧美成人激情图片网| 色偷偷噜噜噜亚洲男人| 国产性色av一区二区| 最近2019中文字幕大全第二页| 亚洲激情视频在线观看| 青青久久av北条麻妃海外网| 欧美一区二粉嫩精品国产一线天| 欧美片一区二区三区| 成人a在线视频| 在线成人中文字幕| 性夜试看影院91社区| 欧美性极品xxxx娇小| 91av在线播放视频| 亚洲精品二三区| 国产欧美精品xxxx另类| 最近免费中文字幕视频2019| 欧美激情视频免费观看| 亚洲小视频在线| 国产成人精品视| 日本欧美国产在线| 亚洲欧洲国产伦综合| 亚洲乱码一区av黑人高潮| 精品亚洲一区二区三区在线播放| 亚洲无av在线中文字幕| 亚洲精品av在线播放| 亚洲精品wwww| 久久久久久com| 亚洲第一中文字幕| 欧美国产日韩xxxxx| 亚州欧美日韩中文视频| 最新69国产成人精品视频免费| 欧美电影免费播放| 国产日本欧美在线观看| 一区二区三区在线播放欧美| 亚洲精品电影在线| 亚洲自拍偷拍一区| 456国产精品| 91国产一区在线| 亚洲天堂网站在线观看视频| 国产97色在线| 91国在线精品国内播放| 国产亚洲精品美女| 亚洲欧美日韩一区在线| 日本一区二区在线免费播放| 久久综合免费视频| 欧美又大粗又爽又黄大片视频| 欧美资源在线观看| 亚洲伊人第一页| 久久夜精品va视频免费观看| 欧美一级在线亚洲天堂| 米奇精品一区二区三区在线观看| 免费不卡欧美自拍视频| 91精品啪aⅴ在线观看国产| 国产香蕉一区二区三区在线视频| 日韩在线视频导航| 久久福利视频网| 亚洲人成网站免费播放| 亚洲国产精品成人va在线观看| 亚洲精品视频免费在线观看| 1769国产精品| 日韩女优人人人人射在线视频| 久久69精品久久久久久久电影好| 久久久久久有精品国产| 懂色av中文一区二区三区天美| 欧亚精品在线观看| 精品国产成人av| 国产亚洲一区二区精品| 欧美国产日本在线| 亚洲欧洲在线看| 国产亚洲aⅴaaaaaa毛片| 久久999免费视频| 国产精品成熟老女人| 日韩在线www| 亚洲二区在线播放视频| 亚洲国产私拍精品国模在线观看| 国产黑人绿帽在线第一区| 欧美日韩性视频在线| 国产这里只有精品| 国产精品国产三级国产aⅴ浪潮| 日韩高清欧美高清| 不卡av电影在线观看| 国产精品网站入口| 亚洲精品成人网| 日本精品中文字幕| 久久99热精品这里久久精品| 国产中文字幕91| 日本一区二区三区四区视频| 国产精品久久久久久久久免费| 国产成人精品视| 亚洲综合在线做性| 欧美成在线观看| 91大神福利视频在线| 精品女同一区二区三区在线播放| 日韩最新中文字幕电影免费看| 国产成人一区二区在线| 国产精品自产拍在线观看|