關(guān)于JavaScript中URL對(duì)象的一些妙用
前言
URL 對(duì)象可能頁(yè)端用的比較少一點(diǎn),一般來(lái)說(shuō),頁(yè)端對(duì) URL 的操作,大部分都是解析 URL 參數(shù),解析 URL 參數(shù)有比較多的庫(kù)可以選,比如 qs,或者用瀏覽器原生的 URLSearchParams
// 假設(shè)當(dāng)前的 url 為 'https://www.test.com?a=1&b=2' const b = new URLSearchParams(location.search); const aParam = b.get('a'); // 1 const bParam = b.get('b'); // 2 const entries = [...b]; // [['a', '1'], ['b', '2']] // 如果希望可以像 qs.parse 一樣獲取一個(gè)對(duì)象,可以這樣做 const params = Object.fromEntries(entries); // {a: 'c', b: '2'}
解析參數(shù)
通過(guò) URLSearchParams 解析參數(shù),和 URL 這個(gè)對(duì)象看起來(lái)關(guān)聯(lián)不是很大,但是可以看下 URL 對(duì)象實(shí)例化之后返回的對(duì)象
const a = new URL('https://www.test.com?a=1&b=2'); // hash: "" // host: "www.test.com" // hostname: "www.test.com" // href: "https://www.test.com/?a=1b=2" // origin: "https://www.test.com" // password: "" // pathname: "/" // port: "" // protocol: "https:" // search: "?a=1&b=2" // searchParams: URLSearchParams {} // username: "" // [[Prototype]]: URL
從返回的對(duì)象可以看到,URL 實(shí)例化之后,返回的屬性 searchParams 實(shí)際上就是一個(gè)實(shí)例化的 URLSearchParams 對(duì)象。所以獲取參數(shù)的操作,其實(shí)也有一個(gè)方法是通過(guò) URL 對(duì)象去獲取,例如上面的操作可以改一下
const a = new URL('https://www.test.com?a=1&b=2'); const entries = [...a.searchParmas]; const params = Object.fromEntries(entries); // 在瀏覽器控制臺(tái),一行 [...new URL(location.href).searchParams];
修改 URL 參數(shù)
淡出的解析參數(shù),沒(méi)必要?jiǎng)佑?URL,用 URLSearchParams 這個(gè)對(duì)象完全是足夠的,那么這個(gè) URL 對(duì)象還可以做什么呢,其實(shí)可以想想 URLSearchParams 其實(shí)提供了 set append 這些寫操作,同時(shí),URL 對(duì)象返回的屬性也是可以修改的,能不能通過(guò)修改 URL 里面的參數(shù),實(shí)現(xiàn)修改一個(gè) URL 或者說(shuō)生成一個(gè) URL ,畢竟很多時(shí)候,對(duì) URL 的修改停留在字符串操作上,操作起來(lái)也很危險(xiǎn),很容易報(bào)錯(cuò)
const a = new URL('https://www.test.com?a=1&b=2'); a.searchParams.set('a', '18'); a.searchParams.set('b', '14'); a.searchParams.set('c', 'test'); let newURL = a.toString(); // https://www.test.com/?a=18&b=14&c=test a.hash = 'hasha'; newURL = a.toString(); // 'https://www.test.com/?a=18&b=14&c=test#hasha' a.host = 'www.init.com'; newURL = a.toString(); // https://www.init.com/?a=18&b=14&c=test#hasha
總結(jié)
URL 對(duì)象在操作 URL 里面還是比較方便的,簡(jiǎn)單封裝一下可以少引很多包了,變通一下,可以反過(guò)來(lái)修改 URL 。這個(gè)對(duì)象在瀏覽器里面可以使用,但是可能面臨著兼容性問(wèn)題,如果是桌面端,放心用(IE 是啥),如果是移動(dòng)端,可能需要配置polyfill。這個(gè)對(duì)象在 deno 中也能使用
到此這篇關(guān)于JavaScript URL對(duì)象的一些妙用的文章就介紹到這了,更多相關(guān)JavaScript URL對(duì)象妙用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
tracking.js頁(yè)面人臉識(shí)別插件使用方法
這篇文章主要為大家詳細(xì)介紹了tracking.js頁(yè)面識(shí)別人臉插件使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11一個(gè)js導(dǎo)致的jquery失效問(wèn)題的解決方法
這篇文章主要介紹了一個(gè)js導(dǎo)致的jquery失效問(wèn)題的解決方法,有需要的朋友可以參考一下2013-11-11js實(shí)現(xiàn)點(diǎn)擊后將文字或圖片復(fù)制到剪貼板的方法
這篇文章主要介紹了js實(shí)現(xiàn)點(diǎn)擊后將文字或圖片復(fù)制到剪貼板的方法,功能非常實(shí)用,需要的朋友可以參考下2014-08-08原生Js實(shí)現(xiàn)元素漸隱/漸現(xiàn)(原理為修改元素的css透明度)
大家經(jīng)??吹骄W(wǎng)頁(yè)里圖片漸變顯示,自己寫一個(gè)。原理很簡(jiǎn)單就是修改元素的css透明度,具體實(shí)現(xiàn)代碼如下,感興趣的各位可以參考下哈,希望對(duì)大家有所幫助2013-06-06JS自動(dòng)生成動(dòng)態(tài)HTML驗(yàn)證碼頁(yè)面
這篇文章主要介紹了JS自動(dòng)生成動(dòng)態(tài)HTML驗(yàn)證碼頁(yè)面,輸入錯(cuò)誤自動(dòng)清空輸入框的功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06你應(yīng)該了解的JavaScript Array.map()五種用途小結(jié)
大家都知道m(xù)ap() 方法返回一個(gè)新數(shù)組,數(shù)組中的元素為原始數(shù)組元素調(diào)用函數(shù)處理后的值。下面這篇文章主要給大家介紹了關(guān)于JavaScript Array.map()的五種用途,需要的朋友可以參考下2018-11-11微信小程序 獲取手機(jī)號(hào) JavaScript解密示例代碼詳解
這篇文章主要介紹了微信小程序 獲取手機(jī)號(hào) JavaScript解密的示例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05ES6中javascript實(shí)現(xiàn)函數(shù)綁定及類的事件綁定功能詳解
這篇文章主要介紹了ES6中javascript實(shí)現(xiàn)函數(shù)綁定及類的事件綁定功能,結(jié)合實(shí)例形式分析了ES6中函數(shù)綁定及類的事件綁定原理、實(shí)現(xiàn)方法、相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2017-11-11