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>
相关推荐
小宁爱Python1 分钟前
Django Web 开发系列(二):视图进阶、快捷函数与请求响应处理
前端·django·sqlite
fox_1 分钟前
深入理解React中的不可变性:原理、价值与实践
前端·react.js
Github项目推荐3 分钟前
你的错误处理一团糟-是时候修复它了-🛠️
前端·后端
Code小翊8 分钟前
C语言bsearch的使用
java·c语言·前端
云枫晖9 分钟前
Webapck系列-初识Webpack
前端·javascript
慧一居士12 分钟前
HTML5 功能介绍,使用场景,对应功能点完整使用示例
前端
海在掘金6112720 分钟前
告别“undefined is not a function”:TS如何让你的函数调用更安心
前端
云中雾丽23 分钟前
Flutter中Stream的各种使用场景和实现方式
前端
CptW26 分钟前
第1篇(Ref):搞定 Vue3 Reactivity 响应式源码
前端·面试
葡萄城技术团队29 分钟前
基于 SpreadJS 的百万级数据在线数据透视表解决方案:技术解析与实践
前端