json对象与json字符串_js和json

Java (3) 2024-06-19 11:23

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说
json对象与json字符串_js和json,希望能够帮助你!!!。

1、Json概念

概念:JSON (JavaScript Object Notation) 一种简单的数据格式,是一种比较轻量级的数据存储格式;

2、Json与JS对象的对比

区 别 JSON JavaScript
含 义 数据格式 类实例
传输 可以跨平台数据传输,速度快 类实例
表现1 键值对的方式,属性必须加双引号 键值对的方式,属性不加双引号
表现2 值不可以是方法函数、undefined以及NAN 值可以是函数、对象、字符串、数字、boolean 等
相互转换1 JSON.parse(str),不兼容IE7 JS对象转换为Json字符串
相互转换2 eval(“(” + str + “)”);(兼容所有浏览器,但是不安全,会执行json里面的表达式) JSON.stringify(obj)

3、Json对象

最显著的特征:对象的值可以用 “对象.属性” 进行访问;
typeOf(json对象) ===> Object类型
例子如下:

var person={ 
   "name":"shily","sex":"女","age":"23"}//json对象 console.log(person); console.log(person.name); console.log(typeof person); 

输出结果是:
json对象与json字符串_js和json_https://bianchenghao6.com/blog_Java_第1张
  
4、Json字符串(所谓字符串:单引号或者双引号引起来)

例子如下:

var person='{"name":"shily","sex":"女","age":"23"}';//json字符串 console.log(person) console.log(person.name) console.log(typeof person) 

输出结果是:
json对象与json字符串_js和json_https://bianchenghao6.com/blog_Java_第2张

5、Json对象与Json字符串的相互转化

Json字符串转化为Json对象( JSON.parse() )

var str = '{"name":"shily","sex":"女","age":"23"}'; var strToObj = JSON.parse(str); console.log(strToObj); console.log(typeof strToObj); console.log(strToObj.name) 

输出结果为:
json对象与json字符串_js和json_https://bianchenghao6.com/blog_Java_第3张

Json对象转化为Json字符串( JSON.stringify() )

var obj = { 
   "name":"shily","sex":"女","age":"23"}//json对象 var objToStr = JSON.stringify(obj); console.log(objToStr); console.log(typeof objToStr) 

输出结果为:
json对象与json字符串_js和json_https://bianchenghao6.com/blog_Java_第4张

6、Json数据在哪种格式下会发生转换

调用第三方接口返回json字符串,我们自己处理成所需格式的json数据?
往JSONObject对象中添加属性及属性值,最后将JSONObjecct对象转成json数据返回?

7、SpringMvc接受Json字符串类型

基于Rest风格的开发,前端ajax提交的是一个json格式的字符串,后台以@RequestBody接受的json对象

<script type="text/javascript"> $(document).ready(function(){ 
    var saveDataAry=[]; var data1={ 
   "userName":"test","address":"gz"}; var data2={ 
   "userName":"ququ","address":"gr"}; saveDataAry.push(data1); saveDataAry.push(data2); $.ajax({ 
    type:"POST", url:"user/saveUser", dataType:"json", contentType:"application/json", data:JSON.stringify(saveData), success:function(data){ 
    } }); }); </script> 

上面代码,首先push方法将其封装到数组中,其表现格式:

[ { 
   "userName":"test","address":"gz"}, { 
   "userName":"ququ","address":"gr"} ] JSON.stringify(saveData)将其转换为json字符串:同时ajax请求的时候也要指定dataType: “json”,contentType:”application/json” 这样就可以轻易的将一个对象或者List传到Java端。 

后台接收

@Controller @RequestMapping(value = "saveUser", method=RequestMethod.POST ) @ResponseBody public void saveUser(@RequestBody List<User> users) { 
    userService.batchSave(users); } 

后台用@RequestBody将其封装到List中。然后进入Service层。

GETPOST方式提时, 根据request header Content-Type的值来判断: application/x-www-form-urlencoded, 可选(即非必须,因为这种情况的数据@RequestParam, @ModelAttribute也可以处理,当然@RequestBody也能处理); multipart/form-data, 不能处理(即使用@RequestBody不能处理这种格式的数据); 其他格式, 必须(其他格式包括application/json, application/xml等。这些格式的数据,必须使用@RequestBody来处理)。 

转载自:https://www.cnblogs.com/wxh0929/p/11132073.html
交流群:

今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

发表回复