1. 程式人生 > 其它 >Json物件和Json字串的區別 Json物件和Json字串的區別

Json物件和Json字串的區別 Json物件和Json字串的區別

Json物件和Json字串的區別

JSON物件

有時候在做專案的時候時常將這兩個概念弄混淆,尤其是在使用springmvc的時候,後臺@RequestBody接受的是一個json格式的字串,一定是一個字串。

先介紹一下json物件,首先說到物件的概念,物件的屬性是可以用:物件.屬性進行呼叫的。例如:

var person={"name":"zhangsan","sex":"男","age":"24"}//json物件
alert(person.name);//zhangsan
alert(typeof person);//object

person就是json物件。可以用perosn.name這種方式進行屬性的呼叫。第三行程式碼就是看person的型別,為object型別。

JSON字串

字串,我們常說的JavaScript中的字串是單引號或者雙引號引起來的。

var person='{"name":"zhangsan","sex":"男","age":"24"}';//json字串
alert(person);//{"name":"zhangsan","sex":"男","age":"24"}
alert(typeof person);//string

person就是一個json字串,之所以叫json字串,因為字串的格式符合json的格式,第三行程式碼也匹配其中的型別為string。

JSON字串和JOSN物件的轉換

json字串轉json物件,呼叫parse方法:

var person='{"name":"zhangsan","sex":"男","age":"24"}';//json字串
var personObject = JSON.parse(person);
alert(personObject.name);//zhangsan

json物件轉為json字串,呼叫stringify方法:

var person={"name":"zhangsan","sex":"男","age":"24"};//json物件
var personString = JSON.stringify(person);
alert(personString);

SpringMVC接受json字串型別。

在SpringMVC中基於REST開發時,前端傳入後臺的應該是一個json格式的字串,而不是一個json物件

<script type="text/javascript">  
    $(document).ready(function(){  
        var saveDataAry=[];  
        var data1={"userName":"zhangsan","address":"bj"};  
        var data2={"userName":"lisi","address":"nj"};  
        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":"zhangsan","address":"bj"},
    {"userName":"lisi","address":"nj"}
]

JSON.stringify(saveData)將其轉換為json字串:同時ajax請求的時候也要指定dataType: “json”,contentType:”application/json” 這樣就可以輕易的將一個物件或者List傳到Java端。

java後臺

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

後臺用@RequestBody將其封裝到List<User>中。然後進入Service層。

GET、POST方式提時, 根據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/ilinuxer/p/6869933.html      

JSON物件

有時候在做專案的時候時常將這兩個概念弄混淆,尤其是在使用springmvc的時候,後臺@RequestBody接受的是一個json格式的字串,一定是一個字串。

先介紹一下json物件,首先說到物件的概念,物件的屬性是可以用:物件.屬性進行呼叫的。例如:

var person={"name":"zhangsan","sex":"男","age":"24"}//json物件
alert(person.name);//zhangsan
alert(typeof person);//object

person就是json物件。可以用perosn.name這種方式進行屬性的呼叫。第三行程式碼就是看person的型別,為object型別。

JSON字串

字串,我們常說的JavaScript中的字串是單引號或者雙引號引起來的。

var person='{"name":"zhangsan","sex":"男","age":"24"}';//json字串
alert(person);//{"name":"zhangsan","sex":"男","age":"24"}
alert(typeof person);//string

person就是一個json字串,之所以叫json字串,因為字串的格式符合json的格式,第三行程式碼也匹配其中的型別為string。

JSON字串和JOSN物件的轉換

json字串轉json物件,呼叫parse方法:

var person='{"name":"zhangsan","sex":"男","age":"24"}';//json字串
var personObject = JSON.parse(person);
alert(personObject.name);//zhangsan

json物件轉為json字串,呼叫stringify方法:

var person={"name":"zhangsan","sex":"男","age":"24"};//json物件
var personString = JSON.stringify(person);
alert(personString);

SpringMVC接受json字串型別。

在SpringMVC中基於REST開發時,前端傳入後臺的應該是一個json格式的字串,而不是一個json物件

<script type="text/javascript">  
    $(document).ready(function(){  
        var saveDataAry=[];  
        var data1={"userName":"zhangsan","address":"bj"};  
        var data2={"userName":"lisi","address":"nj"};  
        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":"zhangsan","address":"bj"},
    {"userName":"lisi","address":"nj"}
]

JSON.stringify(saveData)將其轉換為json字串:同時ajax請求的時候也要指定dataType: “json”,contentType:”application/json” 這樣就可以輕易的將一個物件或者List傳到Java端。

java後臺

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

後臺用@RequestBody將其封裝到List<User>中。然後進入Service層。

GET、POST方式提時, 根據request header Content-Type的值來判斷: 
application/x-www-form-urlencoded, 可選(即非必須,因為這種情況的資料@RequestParam, @ModelAttribute也可以處理,當然@RequestBody也能處理); 
multipart/form-data, 不能處理(即使用@RequestBody不能處理這種格式的資料); 
其他格式, 必須(其他格式包括application/json, application/xml等。這些格式的資料,必須使用@RequestBody來處理)。