JS如何提取URL中的参数并以jason格式返回结果

本文介绍了四种JavaScript方法来从URL中提取查询参数:使用数组循环、正则表达式配合URLSearchParams、entries()方法以及split()和reduce()。展示了如何解析和序列化查询参数以便于后续处理。
摘要由CSDN通过智能技术生成

方法一:使用数组循环

  function serilizeUrl(url) {
      var urlObj = {};
      if (/\?/.test(url)) {
        var urlString = url.subString(url.indexOf('?') + 1);
        var urlArray = urlString.split('&');
        for (var i = 0, len = urlArray.length; i < len; i++) {
          var urlItem = urlArray[i];
          var item = urlItem.split('=');
          urlObj[item[0]] = item[1];
        }
        return urlObj;
      }
      return null;
    }

方法二:使用正则表达式和 URLSearchParams 对象

function extractUrlParams(url) {
    const params = {};
    const queryString = url.split('?')[1];
    
    if (queryString) {
        const searchParams = new URLSearchParams(queryString);
        for (let [key, value] of searchParams) {
            params[key] = value;
        }
    }
    
    return JSON.stringify(params);
}

const url = 'https://www.example.com/?name=Alice&age=30';
const extractedParams = extractUrlParams(url);
console.log(extractedParams);

方法三:使用 URLSearchParams 对象的 entries() 方法

function extractUrlParams(url) {
    const params = {};
    const queryString = url.split('?')[1];
    
    if (queryString) {
        const searchParams = new URLSearchParams(queryString);
        for (let [key, value] of searchParams.entries()) {
            params[key] = value;
        }
    }
    
    return JSON.stringify(params);
}

const url = 'https://www.example.com/?name=Alice&age=30';
const extractedParams = extractUrlParams(url);
console.log(extractedParams);

方法四:使用 split() 方法和 reduce() 方法

function extractUrlParams(url) {
    const params = {};
    const queryString = url.split('?')[1];
    
    if (queryString) {
        queryString.split('&').reduce((acc, param) => {
            const [key, value] = param.split('=');
            acc[key] = decodeURIComponent(value);
            return acc;
        }, params);
    }
    
    return JSON.stringify(params);
}

const url = 'https://www.example.com/?name=Alice&age=30';
const extractedParams = extractUrlParams(url);
console.log(extractedParams);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值