获取URL参数并转换为对象的两种方法

前端获取URL参数并转换为对象的两种方法

本文介绍两种将URL查询参数(location.search)转换为JavaScript对象的常用方法,通过示例代码演示实现过程,并对比分析它们的优缺点。


示例URL

以以下URL为例:
http://localhost:8080/?name=John&age=30&token=abc123&query=a%20b

目标:获取查询参数并转换为对象

预期结果:

javascript 复制代码
{
  name: "John",
  age: "30",
  token: "abc123",
  query: "a b" // 注意URL解码后的空格
}

方法一:传统字符串处理

实现代码

javascript 复制代码
// 方法一:字符串分割方案
const search = window.location.search; // 获取"?name=John&age=30..."
const delInitial = search.substring(1); // 去除问号 → "name=John&age=30..."
const group = delInitial.split("&"); // 拆分为数组 → ["name=John", "age=30..."]

const targetObject = group.reduce((obj, item) => {
  const [key, value] = item.split("="); // 分割键值对
  obj[key] = decodeURIComponent(value); // URL解码处理
  return obj;
}, {});

console.log(targetObject.token); // 输出:abc123

流程解析

  1. 获取原始参数
    window.location.search"?name=John&age=30&token=abc123&query=a%20b"

  2. 去除问号
    substring(1)"name=John&age=30&token=abc123&query=a%20b"

  3. 拆分键值对
    split("&")["name=John", "age=30", "token=abc123", "query=a%20b"]

  4. 构建对象

    通过reduce遍历数组,将每个键值对存入对象


方法二:现代API方案

实现代码

javascript 复制代码
// 方法二:现代API方案
const urlSearchParams = new URLSearchParams(window.location.search);
const params = Object.fromEntries(urlSearchParams.entries());

console.log("🚀 params.token:", params.token); // 输出:abc123
console.log(params.query); // 自动解码 → "a b"

流程解析

  1. 创建URLSearchParams实例

    自动解析查询字符串:new URLSearchParams('?name=John...')

  2. 转换为普通对象
    Object.fromEntries(urlSearchParams.entries()) → 键值对对象

备注:

两种方法 仅适用于简单的获取参数

以及参数不重复的情况下

实际开发中复杂获取可通过router或不使用url传参数

使用接口获取

知识不用记太多 有印象 忘记以后再来查就好

相关推荐
NBtab10 分钟前
Vite + Vue3项目版本更新检查与页面自动刷新方案
前端
天天扭码22 分钟前
来全面地review一下Flex布局(面试可用)
前端·css·面试
用户458203153171 小时前
CSS特异性:如何精准控制样式而不失控?
前端·css
libraG1 小时前
Jenkins打包问题
前端·npm·jenkins
前端康师傅1 小时前
JavaScript 作用域
前端·javascript
前端缘梦1 小时前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
我是天龙_绍1 小时前
使用 TypeScript (TS) 结合 JSDoc
前端
云枫晖1 小时前
JS核心知识-事件循环
前端·javascript
Simon_He1 小时前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
eason_fan2 小时前
Git 大小写敏感性问题:一次组件重命名引发的CI构建失败
前端·javascript