获取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传参数

使用接口获取

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

相关推荐
不一样的少年_30 分钟前
【前端效率工具】再也不用 APIfox 联调!零侵入 Mock,全程不改代码、不开代理
前端·javascript·浏览器
IT_陈寒30 分钟前
JavaScript 性能优化实战:我通过这7个技巧将页面加载速度提升了65%
前端·人工智能·后端
JIngJaneIL33 分钟前
数码商城系统|电子|基于SprinBoot+vue的商城推荐系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·数码商城系统
GISer_Jing40 分钟前
Flutter架构解析:从引擎层到应用层
前端·flutter·架构
GISer_Jing1 小时前
Flutter开发全攻略:从入门到精通
android·前端·flutter
艾小码1 小时前
Vue组件通信不再难!这8种方式让你彻底搞懂父子兄弟传值
前端·javascript·vue.js
lcc1871 小时前
Vue 数据代理
前端·javascript·vue.js
Moment1 小时前
为什么我们从 Python 迁移到 Node.js
前端·后端·node.js
excel1 小时前
📘 全面解析:JavaScript 时间格式化 API 实战指南
前端
咖啡の猫2 小时前
Vue基本路由
前端·vue.js·状态模式