轻松获取 URL 查询参数?分享 1 段优质 JS 代码片段!

大家好,我是大澈!

本文约 600+ 字,整篇阅读约需 1 分钟。

每日分享一段优质代码片段。

今天分享一段优质 JS 代码片段,从而比以往更简单的从 URL 中获取查询参数。

老规矩,先阅读代码片段并思考,再看代码解析再思考,最后评论区留下你的见解!

js 复制代码
const getQueryByName = (name) => {
  const query = new URLSearchParams(location.search)
  return decodeURIComponent(query.get(name))
}
// url: https://sunday.com/?name=fatfish&age=100
const name = getQueryByName('name') // fatfish
const age = getQueryByName('age') // 100
const gender = getQueryByName('gender') // null

分享原因

这段代码通过 URLSearchParams 对象简化了从 URL 中获取查询参数的过程。

通过这种方法,可以更方便地在 JavaScript 中解析和获取 URL 查询参数,特别适用于处理需要从 URL 中提取参数的场景,比如读取用户在网页中的输入或搜索关键字等。

这是项目中一个很常见的操作,之前我们经常会使用 正则表达式 或者 拆分字符串 来完成,现在有了更简单的方式!

代码解析

1. const query = new URLSearchParams(location.search);

创建 URLSearchParams 对象。

URLSearchParams 是 Web API 的一部分,用于操作 URL 的查询字符串。

location.search 返回当前 URL 的查询字符串(例如 ?name=value&key=value)。

URLSearchParams 对象将其解析为一个可以操作的查询参数对象。

2. decodeURIComponent(query.get(name));

query.get(name) 方法从查询参数对象中获取名称为 name 的参数值。

decodeURIComponent 用于对参数值进行解码,以确保返回的值是一个人类可读的字符串,避免 URL 编码带来的问题(例如 %20 代表空格)。

  • end -
相关推荐
kyriewen118 小时前
我开发的 Chrome 扒图浏览器插件又更新了❗
前端·javascript·chrome·科技·ai
晓得迷路了9 小时前
栗子前端技术周刊第 128 期 - Rolldown 1.0、Vitest、Node.js 26.0.0...
前端·javascript·css
qingy_20469 小时前
浏览器页面出现竖向滚动条的解决方案
前端·javascript·vue.js
前端小万9 小时前
用 AI 写了个 VSCode 摸鱼插件,从开发到上架全过程
vue.js
蜡台9 小时前
Vue3 + ECharts 实现地图显示,深蓝色科技风地图、涟漪点、向上连线 ,标签
vue.js·科技·echarts·map·地图
之歆9 小时前
DAY_17深度博客:CSS 响应式布局 · BFC · JavaScript 完全指南(下)
前端·javascript·css
光影少年9 小时前
React18 函数组件执行顺序、严格模式下重复执行问题
前端·javascript·react.js
之歆9 小时前
DAY_20JavaScript 条件语句与循环结构深度学习(一)
前端·javascript
iuu_star9 小时前
跑通最简单的Vue3+Python前后端分离项目
前端·vue.js·python
哆啦A梦158810 小时前
11,Springboot3+vue3个人中心,修改密码
java·前端·javascript·数据库·vue3