当前位置:K88软件开发文章中心编程语言JavaScriptJS02 → 文章内容

JSON.parse()

减小字体 增大字体 作者:佚名  来源:网上搜集  发布时间:2019-1-11 7:07:50

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.parse()