欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于JavaScript中URL對象的一些妙用

 更新時間:2021年10月08日 14:34:21   作者:鳳晴鈴玉  
avaScript URL() 構造函數返回一個新創(chuàng)建的 URL 對象,表示由一組參數定義的 URL,利用該構造函數可以獲取 RL的查詢、參數等,下面這篇文章主要給大家介紹了關于JavaScript URL對象的一些妙用,需要的朋友可以參考下

前言

URL 對象可能頁端用的比較少一點,一般來說,頁端對 URL 的操作,大部分都是解析 URL 參數,解析 URL 參數有比較多的庫可以選,比如 qs,或者用瀏覽器原生的 URLSearchParams

// 假設當前的 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 一樣獲取一個對象,可以這樣做
const params = Object.fromEntries(entries);
// {a: 'c', b: '2'}

解析參數

通過 URLSearchParams 解析參數,和 URL 這個對象看起來關聯不是很大,但是可以看下 URL 對象實例化之后返回的對象

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

從返回的對象可以看到,URL 實例化之后,返回的屬性 searchParams 實際上就是一個實例化的 URLSearchParams 對象。所以獲取參數的操作,其實也有一個方法是通過 URL 對象去獲取,例如上面的操作可以改一下

const a = new URL('https://www.test.com?a=1&b=2');
const entries = [...a.searchParmas];
const params = Object.fromEntries(entries);

// 在瀏覽器控制臺,一行
[...new URL(location.href).searchParams];

修改 URL 參數

淡出的解析參數,沒必要動用 URL,用 URLSearchParams 這個對象完全是足夠的,那么這個 URL 對象還可以做什么呢,其實可以想想 URLSearchParams 其實提供了 set append 這些寫操作,同時,URL 對象返回的屬性也是可以修改的,能不能通過修改 URL 里面的參數,實現修改一個 URL 或者說生成一個 URL ,畢竟很多時候,對 URL 的修改停留在字符串操作上,操作起來也很危險,很容易報錯

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

總結

URL 對象在操作 URL 里面還是比較方便的,簡單封裝一下可以少引很多包了,變通一下,可以反過來修改 URL 。這個對象在瀏覽器里面可以使用,但是可能面臨著兼容性問題,如果是桌面端,放心用(IE 是啥),如果是移動端,可能需要配置polyfill。這個對象在 deno 中也能使用

到此這篇關于JavaScript URL對象的一些妙用的文章就介紹到這了,更多相關JavaScript URL對象妙用內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • tracking.js頁面人臉識別插件使用方法

    tracking.js頁面人臉識別插件使用方法

    這篇文章主要為大家詳細介紹了tracking.js頁面識別人臉插件使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • 一個js導致的jquery失效問題的解決方法

    一個js導致的jquery失效問題的解決方法

    這篇文章主要介紹了一個js導致的jquery失效問題的解決方法,有需要的朋友可以參考一下
    2013-11-11
  • js實現點擊后將文字或圖片復制到剪貼板的方法

    js實現點擊后將文字或圖片復制到剪貼板的方法

    這篇文章主要介紹了js實現點擊后將文字或圖片復制到剪貼板的方法,功能非常實用,需要的朋友可以參考下
    2014-08-08
  • 原生Js實現元素漸隱/漸現(原理為修改元素的css透明度)

    原生Js實現元素漸隱/漸現(原理為修改元素的css透明度)

    大家經常看到網頁里圖片漸變顯示,自己寫一個。原理很簡單就是修改元素的css透明度,具體實現代碼如下,感興趣的各位可以參考下哈,希望對大家有所幫助
    2013-06-06
  • js函數返回多個返回值的示例代碼

    js函數返回多個返回值的示例代碼

    js函數一般都是返回一個值,在本例教程中將為大家介紹下如何返回多個返回值,喜歡的朋友可以了解下
    2013-11-11
  • JS自動生成動態(tài)HTML驗證碼頁面

    JS自動生成動態(tài)HTML驗證碼頁面

    這篇文章主要介紹了JS自動生成動態(tài)HTML驗證碼頁面,輸入錯誤自動清空輸入框的功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 你應該了解的JavaScript Array.map()五種用途小結

    你應該了解的JavaScript Array.map()五種用途小結

    大家都知道m(xù)ap() 方法返回一個新數組,數組中的元素為原始數組元素調用函數處理后的值。下面這篇文章主要給大家介紹了關于JavaScript Array.map()的五種用途,需要的朋友可以參考下
    2018-11-11
  • 微信小程序 獲取手機號 JavaScript解密示例代碼詳解

    微信小程序 獲取手機號 JavaScript解密示例代碼詳解

    這篇文章主要介紹了微信小程序 獲取手機號 JavaScript解密的示例代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • 微信JSSDK上傳圖片

    微信JSSDK上傳圖片

    做過微信開發(fā)的都知道,在部分android機型里微信不支持網頁上傳圖片的,這是由于這些機型的文件上傳存在內存泄漏,會導致微信閃退,所以微信內置瀏覽器將文件上傳屏蔽,本篇文章給大家介紹使用微信jssdk如何上傳圖片,需要的朋友可以關注下
    2015-08-08
  • ES6中javascript實現函數綁定及類的事件綁定功能詳解

    ES6中javascript實現函數綁定及類的事件綁定功能詳解

    這篇文章主要介紹了ES6中javascript實現函數綁定及類的事件綁定功能,結合實例形式分析了ES6中函數綁定及類的事件綁定原理、實現方法、相關操作技巧與注意事項,需要的朋友可以參考下
    2017-11-11

最新評論