标签:const string URLSearchParams value BOM key query 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
顾名思义, 留意注释的部分就可以了
标签:const,string,URLSearchParams,value,BOM,key,query,Query,操作 来源: https://www.cnblogs.com/keatkeat/p/16433157.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。