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

JavaScript獲取URL參數(shù)的方法分享

 更新時間:2022年04月07日 16:52:24   作者:xusx  
這篇文章主要介紹了JavaScript獲取URL參數(shù)的方法分享,主要包括字符串?split?方法、?URLSearchParams?方法、正則匹配方法等,具有一定的參考價值需要的小伙伴可以參考一下

一、字符串 split 方法

url 地址是字符串形式的,所以利用 split 方法將參數(shù)提取出來,該方法比較常用,而且容易理解(無關正則)

let URL = "http://www.baidu.com?name=小宇&age=25&sex=男&wife=小君";
function getUrlParams(url) {
    // 通過 ? 分割獲取后面的參數(shù)字符串
    let urlStr = url.split('?')[1];
    // 創(chuàng)建空對象存儲參數(shù)
	let obj = {};
    // 再通過 & 將每一個參數(shù)單獨分割出來
	let paramsArr = urlStr.split('&');
	for(let i = 0,len = paramsArr.length;i < len;i++){
        // 再通過 = 將每一個參數(shù)分割為 key:value 的形式
		let arr = paramsArr[i].split('=');
		obj[arr[0]] = arr[1];
	}
	return obj;
}
console.log(getUrlParams(URL));

二、使用 URLSearchParams 方法

1、解析搜索字符串

let url = 'https://www.baidu.com/s?ie=UTF-8&wd=%E8%AE%B8%E5%96%84%E7%A5%A5&p=1';
let urlStr = url.split('?')[1];
const params = new URLSearchParams(urlStr);
console.log(params.get('k'));   // 返回字符串“許善祥”,支持自動 UTF-8 解碼
console.log(params.get('p'));   // 返回字符串“1”
console.log(params.get('xxx')); // 如果沒有 xxx 這個鍵,則返回 null
console.log(params.has('xxx')); // 當然也可以通過 has() 方法查詢是否存在指定的鍵
console.log(params.keys());     // 返回一個 ES6 Iterator,內(nèi)含 ['k', 'p']
console.log(params.values());   // 返一個 ES6 Iterator,內(nèi)含 ['許善祥', '1']
console.log(params.entries());  // 與 Map.prototype.entries() 類似

2、生成搜索字符串

const params = new URLSearchParams();
params.set('k', '許善祥');       // 設置參數(shù)
params.set('p', 1);             // 支持 Boolean、Number 等豐富類型
console.log(params.toString()); // k=%E8%AE%B8%E5%96%84%E7%A5%A5&p=1

3、Node.js 代碼

const { URLSearchParams } = require('url');

const urlSearchParams = new URLSearchParams();

三、使用正則匹配方法

正則匹配功能強大,不僅可以實現(xiàn)在登錄注冊時的賬號、密碼、郵箱、手機號等驗證(看這里),還可以非常方便的處理一些字符串(校驗、替換、提取等操作)。

let URL = 'http://www.baidu.com?name=祥&friend=宇';
function getUrlParams3(url){
    // \w+ 表示匹配至少一個(數(shù)字、字母及下劃線),
    // [\u4e00-\u9fa5]+ 表示匹配至少一個中文字符
    let pattern = /(\w+|[\u4e00-\u9fa5]+)=(\w+|[\u4e00-\u9fa5]+)/ig;
    let result = {};
    url.replace(pattern, ($, $1, $2)=>{
        result[$1] = $2;
    });
    return result;
}
console.log(getUrlParams3(URL));
// {name: '祥', friend: '宇'}

四、使用第三方庫 qs

使用第三方庫 qs 也可以實現(xiàn) url 中參數(shù)字符的提取,還能實現(xiàn)將參數(shù)對象轉(zhuǎn)為 url 參數(shù)形式,需要注意的是瀏覽器 cdn 方式引入時是默認添加到全局對象 window 的 Qs 屬性上。

<script src="https://cdn.bootcdn.net/ajax/libs/qs/6.10.3/qs.min.js"></script>
<script>
let URL = 'http://www.baidu.com?name=祥&friend=宇';
function getUrlParams4(url) {
    // 引入 qs 庫時會默認掛在到全局 window 的 Qs 屬性上
    // console.log(window);
    let urlStr = url.split('?')[1];
    let result = Qs.parse(urlStr);
    // 拼接額外參數(shù)
    let otherParams = {
        homepage: 'xushanxiang.com'
    };
    let str = Qs.stringify(otherParams);
    let newUrl = url + str;
    return {result, newUrl};
}
console.log(getUrlParams4(URL));

到此這篇關于JavaScript獲取URL參數(shù)的方法分享的文章就介紹到這了,更多相關JavaScript獲取URL參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 前端傳遞參數(shù)時form-data和json的區(qū)別詳解

    前端傳遞參數(shù)時form-data和json的區(qū)別詳解

    前端可以通FormData對象實現(xiàn)表單形式提交數(shù)據(jù),下面這篇文章主要給大家介紹了關于前端傳遞參數(shù)時form-data和json區(qū)別的相關資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-11-11
  • JS獲取文件大小方法小結(jié)

    JS獲取文件大小方法小結(jié)

    這篇文章主要介紹了JS獲取文件大小的方法,結(jié)合實例總結(jié)分析了JavaScript獲取文件大小的常用技巧,并給出了判斷文件格式與大小的完整實例供讀者參考,需要的朋友可以參考下
    2015-12-12
  • 小程序拖動區(qū)域?qū)崿F(xiàn)排序效果

    小程序拖動區(qū)域?qū)崿F(xiàn)排序效果

    這篇文章主要為大家詳細介紹了小程序拖動區(qū)域?qū)崿F(xiàn)排序效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • 微信小程序事件對象中e.target和e.currentTarget的區(qū)別詳解

    微信小程序事件對象中e.target和e.currentTarget的區(qū)別詳解

    這篇文章主要介紹了微信小程序事件對象中e.target和e.currentTarget的區(qū)別詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • js+css3實現(xiàn)簡單時鐘特效

    js+css3實現(xiàn)簡單時鐘特效

    這篇文章主要為大家詳細介紹了js+css3實現(xiàn)簡單時鐘特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • JavaScript實現(xiàn)跑馬燈抽獎活動實例代碼解析與優(yōu)化(二)

    JavaScript實現(xiàn)跑馬燈抽獎活動實例代碼解析與優(yōu)化(二)

    這篇文章主要介紹了JavaScript實現(xiàn)跑馬燈抽獎活動實例代碼解析與優(yōu)化(二)的相關資料,需要的朋友可以參考下
    2016-02-02
  • JS匿名函數(shù)和匿名自執(zhí)行函數(shù)概念與用法分析

    JS匿名函數(shù)和匿名自執(zhí)行函數(shù)概念與用法分析

    這篇文章主要介紹了JS匿名函數(shù)和匿名自執(zhí)行函數(shù)概念與用法,結(jié)合實例形式分析了匿名函數(shù)和匿名自執(zhí)行函數(shù)的概念、功能、應用場景及相關使用技巧,需要的朋友可以參考下
    2018-03-03
  • 詳解JavaScript是如何驗證URL的

    詳解JavaScript是如何驗證URL的

    當開發(fā)者需要為不同目的以不同形式處理URL時,我們經(jīng)常會借助于JavaScript。本文就為大家整理了JavaScript驗證URL的方法,希望對大家有所幫助
    2023-02-02
  • JavaScript設計模式之職責鏈模式

    JavaScript設計模式之職責鏈模式

    這篇文章主要介紹了JavaScript設計模式之職責鏈模式,對設計模式感興趣的同學,可以參考下
    2021-04-04
  • js微信分享實現(xiàn)代碼

    js微信分享實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了js微信分享的實現(xiàn)代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08

最新評論