JSON.parse()方法将数据转换为javascript对象
来源:互联网 发布:手机八格切图软件 编辑:程序博客网 时间:2024/04/30 20:37
JSON.parse()
JSON 通常用于与服务端交换数据。
在接收服务器数据时一般是字符串。
我们可以使用 JSON.parse() 方法将数据转换为 JavaScript 对象。
语法
JSON.parse(text[, reviver]);
参数说明:
text:必需, 一个有效的 JSON 字符串。
reviver: 可选,一个转换结果的函数, 将为对象的每个成员调用此函数。例如:
var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');
**解析前要确保你的数据是标准的 JSON 格式,否则会解析出错。
你可以使用我们的在线工具检测:https://c.runoob.com/front-end/53。**
实例:
<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h2>从 JSON 对象中创建 JavaScript 对象</h2><p id="demo"></p><script>var obj = JSON.parse('{ "name":"runoob", "alexa":10000, "site":"www.runoob.com" }');document.getElementById("demo").innerHTML = obj.name + ":" + obj.site;</script></body></html>从服务端接收 JSON 数据我们可以使用 AJAX 从服务器请求 JSON 数据,并解析为 JavaScript 对象<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title><h2>使用 XMLHttpRequest 来获取文件内容</h2><p>文件内容是标准的 JSON 格式,可以使用 JSON.parse 方法将其转换为 JavaScript 对象。</p><p id="dem">p = new XMLHttpRequest();xmlhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { myObj = JSON.parse(this.responseText); document.getElementById("demo").innerHTML = myObj.name; }};http.open("GET", "/try/ajax/json_demo.txt", true);xmlhttp.send();script><p>查看 JSON 文件数据 <a href="/try/ajax/json_demo.txt" target="_blank">json_demo.txt</a></p></body></html>从服务端接收数组的 JSON 数据如果从服务端接收的是数组的 JSON 数据,则 JSON.parse 会将其转换为 JavaScript 数组<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h2>内容是数组</h2><p>内容是数组会转换为 JavaScript 数组。</p><p id="demo"></p><script>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();</script><p>查看服务端数据 <a href="/try/ajax/json_demo_array.txt" target="_blank">json_demo_array.txt</a></p></body></html>异常解析数据JSON 不能存储 Date 对象。如果你需要存储 Date 对象,需要将其转换为字符串。之后再将字符串转换为 Date 对象。<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h2>将字符串转换为 Date 对象。</h2><p id="demo"></p><script>var text = '{ "name":"Runoob", "initDate":"2013-12-14", "site":"www.runoob.com"}';var obj = JSON.parse(text);obj.initDate = new Date(obj.initDate);document.getElementById("demo").innerHTML = obj.name + "创建日期: " + obj.initDate;</script></body></html>我们可以启用 JSON.parse 的第二个参数 reviver,一个转换结果的函数,对象的每个成员调用此函数<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h2>字符串转换为 Date 对象</h2><p id="demo"></p><script>var text = '{ "name":"Runoob", "initDate":"2013-12-14", "site":"www.runoob.com"}';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;</script></body></html>解析函数JSON 不允许包含函数,但你可以将函数作为字符串存储,之后再将字符串转换为函数。<!DOCTYPE html><html><head><meta charset="utf-8"><title>菜鸟教程(runoob.com)</title></head><body><h2>字符串转换为函数</h2><p id="demo"></p><script>var text = '{ "name":"Runoob", "alexa":"function () {return 10000;}", "site":"www.runoob.com"}';var obj = JSON.parse(text);obj.alexa = eval("(" + obj.alexa + ")");document.getElementById("demo").innerHTML = obj.name + " Alexa 排名:" + obj.alexa(); </script></body></html>
eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。
不建议在 JSON 中使用函数。
浏览器支持
主流浏览器都支持 JSON.parse() 函数:
Firefox 3.5
Internet Explorer 8
Chrome
Opera 10
Safari 4
感谢菜鸟教程!
阅读全文
0 0
- JSON.parse()方法将数据转换为javascript对象
- JSON.parse()方法,将数据(字符串)转化为javascript对象
- JSON.stringify()方法将javascript对象转换为字符串
- JavaScript将对象转换为JSON
- php数据库数据转换为js中的json对象,JSON.parse()和JSON.stringify()
- 使用Javascript/jQuery将javascript对象转换为json格式数据
- 使用Javascript/jQuery将javascript对象转换为json格式数据
- 使用Javascript/jQuery将javascript对象转换为json格式数据
- javascript将json字符串转换为json对象
- JSON.parse将字符串转换为JSON格式
- JSON.parse():json字符串转化为json对象方法
- javascript 将对象数组转换为json字符串
- 如何将json文本转换为JavaScript对象
- JSON.stringify()将 JavaScript 对象转换为字符串。
- 将Json数据转换为ADO.NET DataSet对象
- 将字符串转换为json对象的方法
- 一种将枚举Enum转换为JSON对象的方法
- 将其他对象转换为JSON对象
- 基于Echart.js一点总结
- 12槽位PCIe扩展箱
- android视频播放器缓存
- Hbase Java API
- Java核心技術卷_2_注釋與數據類型
- JSON.parse()方法将数据转换为javascript对象
- React-Native 安卓出现图片资源路径正确,却无法加载显示
- JAVA 模拟瞬间高并发
- 外观模式(Facade)
- Android 调用echart图表,实现牛逼的效果
- 数据库第一课
- oc 同步、异步图片下载
- mysql数据库定时自动备份
- 打印或者第三方设备