对象数组JS对JSON的操作总结 (转)

查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记录吧!

    对于前端完整是菜鸟,迫于无奈,工作中要用到JS,特别对JSON的处置为多,网上搜了一下,所讲的基本雷同。所以把平时用的比较多的JSON处置方法总结了一下,权当加深记忆。

    一、概述

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完整独立于语言的文本格式,是幻想的数据交换格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处置 JSON数据不须要任何特殊的 API 或工具包。

 在JSON中,有两种结构:对象和数组。

    1.对象

    一个对象以“{”开始,“}”结束。每个“key”后跟一“:”,“‘key/value’ 对”之间运用 “,”分开。

    packJson = {"name":"nikita", "password":"1111"}

    2.数组

    packJson = [{"name":"nikita", "password":"1111"}, {"name":"tony", "password":"2222"}];

    数组是值的有序集合。一个数组以“[”开始,“]”结束。值之间运用 “,”分开。

    二、JSON对象和JSON字符串的转换

    在数据传输流程中,json是以文本,即字符串的情势传递的,而JS操纵的是JSON对象,所以,JSON对象和JSON字符串之间的互相转换是关键。例如:

    JSON字符串:

    var jsonStr = '{"name":"nikita", "password":"1111"}';

    JSON对象:

    var jsonObj = {"name":"nikita", "password":"1111"};

    对于前端完整是菜鸟,迫于无奈,工作中要用到JS,特别对JSON的处置为多,网上搜了一下,所讲的基本雷同。所以把平时用的比较多的JSON处置方法总结了一下,权当加深记忆。

    一、概述

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完整独立于语言的文本格式,是幻想的数据交换格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处置 JSON数据不须要任何特殊的 API 或工具包。

 在JSON中,有两种结构:对象和数组。

    1.对象

    一个对象以“{”开始,“}”结束。每个“key”后跟一“:”,“‘key/value’ 对”之间运用 “,”分开。

    packJson = {"name":"nikita", "password":"1111"}

    2.数组

    packJson = [{"name":"nikita", "password":"1111"}, {"name":"tony", "password":"2222"}];

    数组是值的有序集合。一个数组以“[”开始,“]”结束。值之间运用 “,”分开。

    二、JSON对象和JSON字符串的转换

    在数据传输流程中,json是以文本,即字符串的情势传递的,而JS操纵的是JSON对象,所以,JSON对象和JSON字符串之间的互相转换是关键。例如:

    JSON字符串:

    var jsonStr = '{"name":"nikita", "password":"1111"}';

    JSON对象:

    var jsonObj = {"name":"nikita", "password":"1111"};

    2、String转换为Json

var myObject = eval('(' + myJSONtext + ')'); 
eval是js自带的函数,不是很安全,可以考虑用json包。

    三、遍历JSON对象

对象和数组
myJson = {"name":"nikita", "password":"1111"};

for(var p in myJson){//遍历json对象的每个key/value对,p为key

   alert(p + " " + myJson[p]);

}
运行结果:

    对象和数组

    四、遍历JSON数组

    每日一道理
成功的花朵开放在啊勤劳的枝头,失败的苦果孕育在懒惰的温床之中。
对象和数组
packJson = [

{"name":"nikita", "password":"1111"},

{"name":"tony", "password":"2222"}

];

for(var p in packJson){//遍历json数组时,这么写p为索引,0,1

   alert(packJson[p].name + " " + packJson[p].password);

}
对象和数组
我更倾向于这种写法:
for(var i = 0; i < packJson.length; i++){

   alert(packJson[i].name + " " + packJson[i].password);

}
运行结果:

 对象和数组

 五、将两个JSON对象组装到一个里头

对象和数组
//targetJson 目标JSON,packJson 被组装JSON

function addGroupJson(targetJson, packJson){

    if(targetJson && packJson){

       for(var p in packJson){

           targetJson[p] = packJson[p];

       }

    }

}
对象和数组
用法如下:
var json1 = {"name":"nikita"};
var json2 = {"password":"1111"};
addGroupJson(json1, json2);
alert(json2str(json1));
运行结果:

    对象和数组

文章结束给大家分享下程序员的一些笑话语录: Bphone之你们聊,我先走了!移动说:我在phone前加o,我叫o缝;苹果说:我在phone前i,我是i缝;微软说:我在phone前加w,我叫w缝;三星说:你们聊,我先走了!
将来王建宙写回忆录的时候,一定要有一句“常小兵为中国移动的发展做出了不可磨灭的贡献”。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值