js学习五-JSON
来源:互联网 发布:linux 开启 cron 日志 编辑:程序博客网 时间:2024/05/16 05:50
JavaScript Object Notation,是一种轻量级的数据交换格式
注意:属性名要用“”括起来,构造函数中的属性名不需要用“”括起来
JSON字符串的格式一定要标准,key和value一定要用双引号包括,否则会出线解析异常
特点:轻量级,纯文本,适合不同语言间的交互
方法:
1.JSON.parse(text[,reviver])
text为JSON格式的字符串,JSON.parse 将 JSON 字符串转换为对象
在IE6/7上不支持JSON.parse
将obj对象转换成JSON格式的字符串的格式
在IE6/7上不支持JSON.
注意:属性名要用“”括起来,构造函数中的属性名不需要用“”括起来
JSON字符串的格式一定要标准,key和value一定要用双引号包括,否则会出线解析异常
特点:轻量级,纯文本,适合不同语言间的交互
方法:
1.JSON.parse(text[,reviver])
text为JSON格式的字符串,JSON.parse 将 JSON 字符串转换为对象
在IE6/7上不支持JSON.parse
解决方法:
if(!window.JSON) { window.JSON = {parse:function(sJSON) { return eval('('+sJSON+')')},//eval就是将字符串按照js对象进行处理stringify: function(obj){ var result = ""; for(var key in obj){ if(typeof obj[key] == "string"){ // 如果属性值是String类型,属性值需要加上双引号 result += "\"" + key + "\":\"" + obj[key] + "\","; }else if(obj[key] instanceof RegExp){ // 如果属性是正则表达式,属性值只保留一对空大括号{} result += "\"" + key + "\":{},"; }else if(typeof obj[key] == "undefined" || obj[key] instanceof Function){ // 如果属性值是undefined, 该属性被忽略。忽略方法。 }else if(obj[key] instanceof Array){ // 如果属性值是数组 result += "\"" + key + "\":["; var arr = obj[key]; for(var item in arr){ if(typeof arr[item] == "string"){ // 如果数组项是String类型,需要加上双引号 result += "\"" + arr[item] + "\","; }else if(arr[item] instanceof RegExp){ // 如果属数组项是正则表达式,只保留一对空大括号{} result += "{},"; }else if(typeof arr[item] == "undefined" || arr[item] instanceof Function){ // 如果数组项是undefined, 则显示null。如果是函数,则显示null?。 result += null +","; }else if(arr[item] instanceof Object){ //如果数组项是对象(非正则,非函数,非null),调用本函数处理 result += this.stringify(arr[item]) +","; }else{ result += arr[item] + ","; } } result = result.slice(0,-1)+"]," }else if(obj[key] instanceof Object){ // 如果属性值是对象(非null,非函数,非正则),调用本函数处理 result += "\"" + key + "\":" + this.stringify(obj[key]) + ","; }else{ result += "\"" + key + "\":" + obj[key] + ","; } } // 去除最后一个逗号,两边加{} return "{" + result.slice(0,-1) + "}"; }};}2.JSON.stringify(obj)
将obj对象转换成JSON格式的字符串的格式
在IE6/7上不支持JSON.
code
<!DOCTYPE html><html><head><meta charset="utf-8"><title>JSON</title></head><body><script type="text/javascript">var onepiece = {id:1,nick:"caomao",name:"lufei",status:"captain",years:"18"};var test = '{"id":1,"nick":"caomao","name":"lufei","status":"captain","years":"18"}';var op1 = JSON.stringify(onepiece);// var op2 = JSON.parse(onepiece);console.log('op1');console.log(op1);// {"id":1,"nick":"caomao","name":"lufei","status":"captain","years":"18"}var op2 = JSON.stringify(onepiece, ['id','name','status']);console.log(op2)//{"id":1,"name":"lufei","status":"captain"}只显示JSON对象中的部分信息var op3 = JSON.parse(test);//JSON.parse 将 JSON 字符串转换为对象console.log(op3);// Object {id: 1, nick: "caomao", name: "lufei", status: "captain", years: "18"}debugger;</script></body></html>
0 0
- js学习五-JSON
- JSON学习笔记(五)- JSON.stringify()
- JS学习笔记----------(五)
- JS 学习5 json
- JS学习笔记-JSON
- js学习笔记:JSON
- JS学习九----JSON
- Angular JS 学习笔记五
- processing.js 学习(五)
- json学习(java,js)
- Ajax/json/js 学习备忘
- js原生JSON学习笔记
- 深入学习js中的json
- JS学习17(JSON)
- MDN JS学习之json
- JS,JSON,NodeJS学习笔记
- JSON学习五——>简单总结
- ajax,json学习笔记(五)总结
- HEX文件与BIN文件的区别
- Fragment事务及Fragment实现选项卡功能
- 用Xstream解析XML
- IDEA下JNI开发快速生成头文件方法
- 数据结构-平衡二叉树(AVL Tree)
- js学习五-JSON
- 待续(四)spark学习系列
- CadenceIC5141安装总结
- 2016百度之星资格赛 B题
- Google 发布的15个 Android 性能优化典范(一)
- HDU 1007 Quoit Design
- Android学习第一天随手记(啃食API中)
- 跟着郝斌学数据结构(06)——队列(数组队列基本的一些问题)
- STM32调试CAN总线RxMessage.Id异常