浅谈 Json

       眨眼睛之间就来到了十二月了,一年过的真的是快的很,今儿个也没想到有啥好写的,突然想到前段时间弄的阿里语音识别里面的 JSON , 感觉 JSON  数据也是个很有趣的东西,所以针对它,我做了一个简单的调研的吧,下面就是我对 JSON 的个人理解。

 

一:什么是 Json

 

二:解析 Json 数据

 

三:Json 与 Xml 对比

 

四:解析时遇到的坑

 

 

什么是 Json

Json (Javascript Object Notation) 是一种轻量级的数据交换格式,相比于xml这种数据交换格式来说,因为解析xml比较的复杂,而且需要编写大段的代码,所以客户端和服务器的数据交换格式往往通过json来进行交换。尤其是对于web开发来说,json数据格式在客户端直接可以通过javascript来进行解析。

 

Json一共有两种数据结构,一种是以 (key/value)对形式存在的无序 JsonObject对象,一个对象以  “{”(左花括号)开始,“}”(右花括号) 结束。每个 “名称” 后跟一个 “:”(冒号); “‘名称/值’ 对”之间使用“,”(逗号) 分隔

例如: {"name": "xiaoluo"} , 这就是一个最简单的json对象,对于这种数据格式,key值必须要是string类型,而对于value,则可以是string、number、object、array等数据类型

 

另一种数据格式就是有序的value的集合,这种形式被称为是jsonArray,数组是值(value)的有序集合。一个数组以  “[”(左中括号)开始,“]”(右中括号) 结束。值之间使用“,”(逗号)分隔。

 

例如:   [ {  "id" : "123", "courseID" : "huangt-test", "title" : "提交作业" }] ;

 

 

解析 Json 数据 <

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
form-data转json的方法可以使用JavaScript中的FormData对象和serializeArray()方法来实现。首先,我们可以使用FormData对象来获取表单中的所有数据,然后使用serializeArray()方法将FormData对象转换为一个包含键值对的数组。接下来,我们可以遍历这个数组,将每个键值对转换为一个JSON对象。在转换过程中,我们可以根据需要对值进行自定义处理,比如将空值转换为null。最后,将所有的JSON对象组合成一个对象数组并返回。 以下是一个示例代码,用于将form-data转换为JSON对象数组: ```javascript function transformToJson(form) { var jsonData = {}; var formData = new FormData(form); var formArray = $(form).serializeArray(); $.each(formArray, function() { var dataType = $("select\[name='" + this.name + "'\]").attr("data-type"); var value = this.value; if (value == "无" || value == "") { value = null; } if (jsonData\[this.name\]) { if (!jsonData\[this.name\].push) { jsonData\[this.name\] = \[jsonData\[this.name\]\]; } jsonData\[this.name\].push(value || ''); } else { if (dataType == 'array') { jsonData\[this.name\] = \[\]; jsonData\[this.name\].push(value || ''); } else { jsonData\[this.name\] = value || ''; } } }); return jsonData; } ``` 这个函数接受一个表单作为参数,并返回一个转换后的JSON对象数组。你可以将表单元素传递给这个函数,然后使用返回的JSON对象数组进行后续操作。 引用\[1\]中提到了form-data的两种格式:multipart/form-data和x-www-form-urlencoded。这个函数适用于x-www-form-urlencoded格式的form-data转换为JSON对象数组。如果你需要处理multipart/form-data格式的form-data,你可能需要使用其他方法来解析和处理这种格式的数据。 希望这个回答对你有帮助!\[1\]\[2\] #### 引用[.reference_title] - *1* *3* [浅谈 JSON 对象和 FormData 相互转换,打通前端与后端的通信血脉](https://blog.csdn.net/Shids_/article/details/128931933)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [表单数据转换为JSON对象 3种方法](https://blog.csdn.net/weixin_60664977/article/details/124453249)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值