- ·上一篇文章:JSON 数组
- ·下一篇文章:JSON.stringify()
当前位置:K88软件开发 → 文章中心 → 编程语言 → JavaScript → JS02 → 文章内容
JSON.parse()
JSON.parse()JSON 通常用于与服务端交换数据。在接收服务器数据时一般是字符串。我们可以使用 JSON.parse() 方法将数据转换为 JavaScript 对象。语法JSON.parse(text[, reviver])参数说明:text:
必需, 一个有效的 JSON 字符串。reviver:
可选,一个转换结果的函数, 将为对象的每个成员调用此函数。JSON 解析实例例如我们从服务器接收了以下数据:{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }我们使用 JSON.parse() 方法处理以上数据,将其转换为 JavaScript 对象:var obj = JSON.parse('{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }');解析前要确保你的数据是标准的 JSON 格式,否则会解析出错。你可以使用我们的在线工具检测:https:
//c.k88.net/front-end/53。解析完成后,我们就可以在网页上使用 JSON 数据了:实例<p id="demo"></p><script>var obj = JSON.parse('{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }');document.getElementById("demo").innerHTML = obj.name + ":" + obj.site;</script>尝试一下 ?从服务端接收 JSON 数据我们可以使用 AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象。实例var xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function() {if (this.readyState == 4 && this.status == 200) {myObj = JSON.parse(this.responseText);document.getElementById("demo").innerHTML = myObj.name;}};xmlhttp.open("GET", "/try/ajax/json_demo.txt", true);xmlhttp.send();尝试一下 ?查看服务端数据: json_demo.txt从服务端接收数组的 JSON 数据如果从服务端接收的是数组的 JSON 数据,则 JSON.parse 会将其转换为 JavaScript 数组:实例var xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function() {if (this.readyState == 4 && this.status == 200) {myArr = JSON.parse(this.responseText);document.getElementById("demo").innerHTML = myArr[1];}};xmlhttp.open("GET", "/try/ajax/json_demo_array.txt", true);xmlhttp.send();尝试一下 ?查看服务端数据: json_demo_array.txt异常解析数据JSON 不能存储 Date 对象。如果你需要存储 Date 对象,需要将其转换为字符串。之后再将字符串转换为 Date 对象。实例var text = '{ "name":
"Runoob", "initDate":
"2013-12-14", "site":
"www.k88.net"}';var obj = JSON.parse(text);obj.initDate = new Date(obj.initDate);document.getElementById("demo").innerHTML = obj.name + "创建日期:
" + obj.initDate;尝试一下 ?我们可以启用 JSON.parse 的第二个参数 reviver,一个转换结果的函数,对象的每个成员调用此函数。实例var text = '{ "name":
"Runoob", "initDate":
"2013-12-14", "site":
"www.k88.net"}';var obj = JSON.parse(text, function (key, value) {if (key == "initDate") {return new Date(value);} else {return value;}});document.getElementById("demo").innerHTML = obj.name + "创建日期:" + obj.initDate;尝试一下 ?解析函数JSON 不允许包含函数,但你可以将函数作为字符串存储,之后再将字符串转换为函数。实例var text = '{ "name":
"Runoob", "alexa":
"function () {return 10000;}", "site":
"www.k88.net"}';var obj = JSON.parse(text);obj.alexa = eval("(" + obj.alexa + ")");document.getElementById("demo").innerHTML = obj.name + " Alexa 排名:" + obj.alexa();尝试一下 ?不建议在 JSON 中使用函数。浏览器支持主流浏览器都支持 JSON.parse() 函数:Firefox 3.5Internet Explorer 8ChromeOpera 10Safari 4
必需, 一个有效的 JSON 字符串。reviver:
可选,一个转换结果的函数, 将为对象的每个成员调用此函数。JSON 解析实例例如我们从服务器接收了以下数据:{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }我们使用 JSON.parse() 方法处理以上数据,将其转换为 JavaScript 对象:var obj = JSON.parse('{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }');解析前要确保你的数据是标准的 JSON 格式,否则会解析出错。你可以使用我们的在线工具检测:https:
//c.k88.net/front-end/53。解析完成后,我们就可以在网页上使用 JSON 数据了:实例<p id="demo"></p><script>var obj = JSON.parse('{ "name":
"k88", "alexa":
10000, "site":
"www.k88.net" }');document.getElementById("demo").innerHTML = obj.name + ":" + obj.site;</script>尝试一下 ?从服务端接收 JSON 数据我们可以使用 AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象。实例var xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function() {if (this.readyState == 4 && this.status == 200) {myObj = JSON.parse(this.responseText);document.getElementById("demo").innerHTML = myObj.name;}};xmlhttp.open("GET", "/try/ajax/json_demo.txt", true);xmlhttp.send();尝试一下 ?查看服务端数据: json_demo.txt从服务端接收数组的 JSON 数据如果从服务端接收的是数组的 JSON 数据,则 JSON.parse 会将其转换为 JavaScript 数组:实例var xmlhttp = new XMLHttpRequest();xmlhttp.onreadystatechange = function() {if (this.readyState == 4 && this.status == 200) {myArr = JSON.parse(this.responseText);document.getElementById("demo").innerHTML = myArr[1];}};xmlhttp.open("GET", "/try/ajax/json_demo_array.txt", true);xmlhttp.send();尝试一下 ?查看服务端数据: json_demo_array.txt异常解析数据JSON 不能存储 Date 对象。如果你需要存储 Date 对象,需要将其转换为字符串。之后再将字符串转换为 Date 对象。实例var text = '{ "name":
"Runoob", "initDate":
"2013-12-14", "site":
"www.k88.net"}';var obj = JSON.parse(text);obj.initDate = new Date(obj.initDate);document.getElementById("demo").innerHTML = obj.name + "创建日期:
" + obj.initDate;尝试一下 ?我们可以启用 JSON.parse 的第二个参数 reviver,一个转换结果的函数,对象的每个成员调用此函数。实例var text = '{ "name":
"Runoob", "initDate":
"2013-12-14", "site":
"www.k88.net"}';var obj = JSON.parse(text, function (key, value) {if (key == "initDate") {return new Date(value);} else {return value;}});document.getElementById("demo").innerHTML = obj.name + "创建日期:" + obj.initDate;尝试一下 ?解析函数JSON 不允许包含函数,但你可以将函数作为字符串存储,之后再将字符串转换为函数。实例var text = '{ "name":
"Runoob", "alexa":
"function () {return 10000;}", "site":
"www.k88.net"}';var obj = JSON.parse(text);obj.alexa = eval("(" + obj.alexa + ")");document.getElementById("demo").innerHTML = obj.name + " Alexa 排名:" + obj.alexa();尝试一下 ?不建议在 JSON 中使用函数。浏览器支持主流浏览器都支持 JSON.parse() 函数:Firefox 3.5Internet Explorer 8ChromeOpera 10Safari 4
JSON.parse()