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

31 篇文章 0 订阅
23 篇文章 0 订阅

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

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

1. URLSearchParams

URLSearchParams: 详细文档 URLSearchParams接口参考

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

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

JSCopy to Clipboard

for (const [key, value] of mySearchParams) {
}
for (const [key, value] of mySearchParams.entries()) {
}

具体转换案例如下

<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 的格式。
<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 对象。
<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>
  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值