BOM – 操作 Query
前言
ASP.NET Core 写过一篇关于操作 query 的 ASP.NET Core – 操作 Uri 和 Query. 前端偶尔也会需要做出 query.
URLSearchParams
之前讲 JavaScript – Fetch 就已经有用到 URLSearchParams 了. 但主要是用来生成 query. 这篇 read / write 都讲.
Read From URL
const query = new URLSearchParams(location.search);
在前端, search 指的就是 ?Query.
location.search 返回的是 ?key=value 这样的 string. 它是还没有 decode 的哦.
new URLSearchParams 初始化传入一个 string, 它就会去 parse 它. 这个 string 最好是以 ? 开头. 或者 search 去掉问号只留下 key=value&key1=value2 这样.
/path?key=value <-- 这样就不 ok, 会 parse 失败哦.
get and getAll
const value = query.get('key'); // no match return null const values: string[] = query.getAll('key'); // no match return empty array
getAll 是针对 same key 的情况, 比如 'key=value&key=value2'
获取到的值都是 decode 好了的.
for of 遍历
URLSearchParams 是 iterable
for (const [key, value] of query) { console.log("key value", [key, value]); }
如果 same key, 那么会 loop 2 次.
has, append, delete, toString
const query = new URLSearchParams(); const hasKey = query.has("key"); query.append("key", "= will auto encode"); // auto encode query.delete("key"); query.append("key", "= will auto encode"); const finalSearch = query.toString(); // not starts with ? console.log("finalSearch", finalSearch); // key=%3D+will+auto+encode
顾名思义, 留意注释的部分就可以了
Encode/Decode 空格
Space 空格 encode 后会变成 + 加号,而不是 %20 哦
const urlSearchParams = new URLSearchParams(); urlSearchParams.append('key', 'value 1'); console.log(urlSearchParams.toString()); // key=value+1
decode 时则 + 加号,或者 %20 都会变成 space 空格。
const urlSearchParams = new URLSearchParams('key1=value+1&key2=value%202'); console.log(urlSearchParams.get('key1')); // value 1 console.log(urlSearchParams.get('key2')); // value 2
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
2021-07-01 聊聊 iframe, CSP, 安全, 跨域
2021-07-01 Asp.net core 学习笔记之 Microsoft Graph API