js解析與序列化json數據(三)json的解析探討
更新時間:2013年02月01日 12:14:36 作者:
這一節(jié)我們主要討論json的解析,感興趣的朋友可以了解下,JSON.parse()方法也可以接收另一個參數,該參數是一個函數,將早每個鍵值對上調用,好了,話不多說,希望本文對你有所幫助
這一節(jié)我們主要討論json的解析。
JSON.parse()方法也可以接收另一個參數,該參數是一個函數,將早每個鍵值對上調用。為了區(qū)別JSON.stringify()接收的替換(過濾)函數(replacer),這個函數被稱作還原函數(reviver),但實際上這兩個函數的簽名是相同的——它們都接收連個參數,一個鍵和一個值,而且都需要返回一個值。
如果還原函數返回undefined,則表示要從結果中刪除相應的鍵;如果返回其他值,則將該值插入到結果中。如:
<html>
<head>
<title></title>
<script type="text/javascript">
function init()
{
var student={
name:"Bill",
birthDate:new Date(1990,8,4)
};
var jsonText=JSON.stringify(student);
var studentObject=JSON.parse(jsonText,function(key,value){
if(key=="birthDate")
{
return new Date(value);
}
else
{
return value;
}
});
}
</script>
</head>
<body>
<input type="button" onclick="init()" value="測試" />
</body>
</html>
以上代碼先是為student添加了出生日期birthDate屬性,該屬性保存著一個Date對象。這個對象在經過序列化之后變成了有效地JSON字符串,然后經過解析又在studentObject中還原為一個Date對象。
JSON.parse()方法也可以接收另一個參數,該參數是一個函數,將早每個鍵值對上調用。為了區(qū)別JSON.stringify()接收的替換(過濾)函數(replacer),這個函數被稱作還原函數(reviver),但實際上這兩個函數的簽名是相同的——它們都接收連個參數,一個鍵和一個值,而且都需要返回一個值。
如果還原函數返回undefined,則表示要從結果中刪除相應的鍵;如果返回其他值,則將該值插入到結果中。如:
復制代碼 代碼如下:
<html>
<head>
<title></title>
<script type="text/javascript">
function init()
{
var student={
name:"Bill",
birthDate:new Date(1990,8,4)
};
var jsonText=JSON.stringify(student);
var studentObject=JSON.parse(jsonText,function(key,value){
if(key=="birthDate")
{
return new Date(value);
}
else
{
return value;
}
});
}
</script>
</head>
<body>
<input type="button" onclick="init()" value="測試" />
</body>
</html>
以上代碼先是為student添加了出生日期birthDate屬性,該屬性保存著一個Date對象。這個對象在經過序列化之后變成了有效地JSON字符串,然后經過解析又在studentObject中還原為一個Date對象。
相關文章
利用NodeJS的子進程(child_process)調用系統命令的方法分享
child_process即子進程可以創(chuàng)建一個系統子進程并執(zhí)行shell命令,在與系統層面的交互上挺有用處2013-06-06
json.stringify()與json.parse()的區(qū)別以及用處
這篇文章主要介紹了json.stringify()與json.parse()的區(qū)別以及用處,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01

