相思资源网 Design By www.200059.com
本文实例总结了JSON遍历方式。分享给大家供大家参考,具体如下:
第一种:使用for循环
js代码:
function CyclingJson1() { var testJson = '[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]'; testJson = eval("(" + testJson + ")"); for (var i = 0; i < testJson.length; i++) { alert(testJson[i].name); } }
第二种:使用关键字in
js代码:
function CyclingJson2() { var testJson = '[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]'; testJson = eval("(" + testJson + ")"); for (var i in testJson) { alert(testJson[i].name); } }
第三种;使用jquery.each()函数
function CyclingJson3() { var testJson = '[{ "name": "小强", "age": 16 },{"name":"小明","age":17}]'; testJson = eval("(" + testJson + ")"); $.each(testJson, function (i, n) { alert(i); //i为索引值 alert(n.name); //n为遍历的值 }); }
综合实例:
<script language="javascript" type="text/javascript"> var array = { "a": "abc", "b": [1, 2, 3, 4, 5, 6], "c": 3, "d": { "name": "james", "age": 28},"e":null,"f":true }; var arrayObj = { "a": { "name": "kobe", "age": 34 }, "b": { "name": "lofo", "age": 28} }; //遍历array方式1 for (var x in array) { if (typeof array[x] == 'object' && array[x] != null ) { for (var y in array[x]) { alert("key = " + y + " value = " + array[x][y]); } } else { alert("key = " + x + " value = " + array[x]); // 非array object } } //遍历array方式2 $.each(array, function(k, v) { var a = typeof (v); //数组与对象为object类型,其他分别是string与number类型 //此时的k代表a、b、c、d,v代表对应的值 if (typeof (v) == "object") { //获取数组与对象后,再去遍历这个数组与对象 $.each(v, function(k1, v1) { window.alert("key = " + k1 + " value=" + v1); }); } else { window.alert("key = " + k + " value=" + v); } }); //遍历arrayObj方式1 for (var x in arrayObj) { for (var key in arrayObj[x]) { window.alert("key=" + key + " value=" + arrayObj[x][key]); } } //遍历arrayObj方式2 $.each(arrayObj, function(key, value) { $.each(value, function(k, v) { window.alert("key=" + k + " value=" + v); }); }); //遍历arrayObj方式3 $.each(arrayObj, function(key, value) { window.alert("key=" + key + " valueName=" + value.name + " valueAge=" + value.age); }); </script> <script language="javascript" type="text/javascript"> var UserList = [ { "UserID": 11, "Name": { "FirstName": "Truly", "LastName": "Zhu" }, "Email": "" }, { "UserID": 12, "Name": { "FirstName": "Jeffrey", "LastName": "Richter" }, "Email": "" }, { "UserID": 13, "Name": { "FirstName": "Scott", "LastName": "Gu" }, "Email": "" } ] $.each(UserList, function(k, v) { $.each(v, function(k1, v1) { if (typeof (v1) == "object") { $.each(v1, function(k2, v2) { window.alert("key=" + k2 + " value=" + v2); }); } else { window.alert("key=" + k1 + " value=" + v1); } }); }); </script> <script language="javascript" type="text/javascript"> var userArray = [ { "UserID": 11, "Name": { "FirstName": "Truly", "LastName": "Zhu" }, "Email": "" }, { "UserID": 12, "Name": { "FirstName": "Jeffrey", "LastName": "Richter" }, "Email": "" }, { "UserID": 13, "Name": { "FirstName": "Scott", "LastName": "Gu" }, "Email": "" } ]; for (var i in userArray) { for (var k in userArray[i]) { if (typeof userArray[i][k] == "object" && userArray[i][k] != null) { for (var j in userArray[i][k]) { window.alert("key=" + j + "--value=" + userArray[i][k][j]); } } else { window.alert("key=" + k + "--value=" + userArray[i][k]); } } } </script>
希望本文所述对大家JavaScript程序设计有所帮助。
标签:
JSON,遍历,JSON遍历
相思资源网 Design By www.200059.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
相思资源网 Design By www.200059.com
暂无JSON遍历方式实例总结的评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。