JavaScript中JSON对象属性与URL参数之间相互转换实现

JavaScript中JSON对象属性与URL参数之间相互转换实现

文章目录

1. JSON对象转换为URL参数字符串

1. URLSearchParams

URLSearchParams: 详细文档 URLSearchParams接口参考

URLSearchParams 接口定义了一些实用的方法来处理 URL 的查询字符串。

一个实现了 URLSearchParams 的对象可以直接用在 for...of 结构中,以键/值对在查询字符串中出现的顺序对它们进行迭代,例如下面两行是等价的:

JSCopy to Clipboard

js 复制代码
for (const [key, value] of mySearchParams) {
}
for (const [key, value] of mySearchParams.entries()) {
}

具体转换案例如下

js 复制代码
<script>
   //obj对象
    const obj = {
        page: 1,
        size: 10,
        sort: 'id',
        order: 'desc',
        other: null
    };
   //方式1:

   let urlParams = new URLSearchParams(obj).toString()

   console.log(urlParams)
   //输出如下:
   //page=1&size=10&sort=id&order=desc&other=null
</script>

2. Object.keys

如下jsonToQueryString 函数将 JSON 对象转换为 URL 参数字符串。

  1. 遍历 JSON 对象的属性,编码键和值;
  2. 然后拼接成形如 key1=value1&key2=value2 的格式。
js 复制代码
<script>
   function jsonToQueryString(json) {
       return Object.keys(json)
           .map(key => encodeURIComponent(key) + '=' + encodeURIComponent(json[key]))
           .join('&');
   }

   // 示例
   const json = { name: 'zhangSan', age: 30, city: 'beijing' };
   const queryString = jsonToQueryString(json);
   console.log(queryString);
   //输出如下
   // name=zhangSan&age=30&city=beijing
</script>

2. URL参数字符串转换为JSON对象:

如下queryStringToJson 函数将 URL 参数字符串转换为 JSON 对象。

  1. 首先对 URL 参数字符串做处理;
  2. 然后使用 JSON.parse() 方法将其转换为 JSON 对象。
js 复制代码
<script>
   function queryStringToJson(queryString) {
   return JSON.parse('{"' + decodeURI(queryString).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g,'":"') + '"}');
   }

   // 示例
   const queryStr = "name=zhangSan&age=30&city=beijing";
   const queryStrToJson = queryStringToJson(queryStr);
   console.log(queryStrToJson);
   //输出如下
   /*{
       "name": "zhangSan",
       "age": "30",
       "city": "beijing"
   }*/
</script>
     "name": "zhangSan",
       "age": "30",
       "city": "beijing"
   }*/
</script>
相关推荐
Csvn8 小时前
OpenSpec 详细使用教程
前端
之歆9 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
云水一下10 小时前
HTML5 从入门到精通:实战收官——从零搭建完整静态网站,综合运用所有知识
前端·html5
不总是10 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
冬奇Lab10 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
NiceCloud喜云11 小时前
Claude Code Routines 实战:三种触发器跑通云端自动化编码
android·运维·数据库·人工智能·自动化·json·飞书
zhangyao94033011 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
XinZong11 小时前
实测OpenClaw虾淘:全民工具AI时代,冷门非工具类的Skill还能出圈吗?
javascript
kjs--11 小时前
浏览器书签执行脚本
前端
烛衔溟11 小时前
TypeScript 类的类型 —— 作为类型使用
javascript·ubuntu·typescript