zoukankan      html  css  js  c++  java
  • cocos-html5 Json 灵活 遍历方式 不同方式的缺陷,优点总结

    1,四种解析Json的方式:
    Part 1

    var list1 = [1,3,4];
    alert(list1[1]);
    var list2 = [{"name":"leamiko","xing":"lin"}];
    alert(list2[0]["xing"])
    alert(list2[0].xing)
    

    解释:括号 和 点号  都能获取属性值。 js 处理 JSON 的灵活性
    Part 2

    var value = {
    	"china":{
    		"hangzhou":{"item":"1"},
    		"shanghai":{"item":"2"},
    		"chengdu":{"item":"3"}
    	},
    	"America":{
    		"aa":{"item":"1"},
    		"bb":{"item":"2"}    
    	},
    	"Spain":{
    		"dd":{"item":"1"},
    		"ee":{"item":"2"},
    		"ff":{"item":"3"}    
    	}
    };
    
    for(var countryObj in value)
    {
    	document.write(countryObj + ":<br />")
    	//没用的for(var cityObj in value.countryObj)
    	for(var cityObj in value[countryObj])
    	{
    		document.write('    ' + cityObj + "<br />");
    		for(var itemObj in value[countryObj][cityObj])
    		{
    			document.write("      "+ itemObj + value[countryObj][cityObj][itemObj] +"<br />")    
    		}
    	}    
    }    
    

     

    解释:

    countryObj 为value对象的一个属性名,value[countryObj] 为value对象的属性值 这里为一个json对象比如b,value[countryObj][cityObj]为josn对象b的属性值 它也是一个json对象,于是 value[countryObj][cityObj]["item"]便可以取到json对象暂时成为c的值,或者 value[countryObj][cityObj].item。

    总之分清是json还是array这是很关键的。

    Part 3

    var value2 = {
        "china":[
            {"name":"hangzhou", "item":"1"},
            {"name":"shanghai", "item":"2"},
            {"name":"sichuan", "item":"3"}
        ],
        "America":[
            {"name":"aa", "item":"12"},
            {"name":"bb", "item":"2"}
        ],
        "Spain":[
            {"name":"cc", "item":"1"},
            {"name":"dd", "item":"23"},
            {"name":"ee", "item":"3"}
        ]
    };
      
    for (var countryObj in value2)
    {
        document.write(countryObj + ":<br />")    
        for (var cityObj in value2[countryObj])
        {
            //可以用document.write("&nbsp;&nbsp;" + value2[countryObj][cityObj].item + "<br />");
            document.write(cityObj + "&nbsp;&nbsp;" + value2[countryObj][cityObj]["name"] + "<br />" );    
        }
    }

    解释:

    countryObj 为value2对象的属性名,value2[countryObj] 为value2对象属性值 在本例中它是一个数组,cityObj 是数组的一个元素,它又是另外一个json对象,于是,value2[countryObj][cityObj]["name"]就访问到该对象的 name的属性值,也可以通过 value2[countryObj][cityObj].name 来访问该属性值。

    Part 4

    var value2 = {
    	"china":[
    		{"name":"hangzhou", "item":"1"},
    		{"name":"shanghai", "item":"2"},
    		{"name":"sichuan", "item":"3"}
    	],
    	"America":[
    		{"name":"aa", "item":"12"},
    		{"name":"bb", "item":"2"}
    	],
    	"Spain":[
    		{"name":"cc", "item":"1"},
    		{"name":"dd", "item":"23"},
    		{"name":"ee", "item":"3"}
    	]
    };
      
    	for (var countryObj in value2)
    	{
    		document.write(countryObj + ":<br />")    
    		//document.write("  " + value2[countryObj].length);
    		for (var i = 0;i < value2[countryObj].length; i++)
    		{
    			document.write("  " + value2[countryObj][i]["name"] + "<br />");    
    		}
    	}
    

    解释:

    countryObj value2对象的属性名,value2[countryObj] 属性值 本例中是一个数组,value2[countryObj].length 数组的长度,value2[countryObj][i]数组的项 == json对象。

    value2[countryObj][i]["name"] 取得name的值,也可以用value2[countryObj][i].name 来取得name的值。

      
    总结: ["name"] 方式 获取JSON 是标准方式,  .name 方式 不是标准方式(但是符合人类思考方式,常用),但是有缺陷,如果name 是数字,获取方式就失败了,标准方式没问题.....

     

  • 相关阅读:
    Java中异常的捕获与处理
    vue动态绑定class的最常用几种方式:
    JS常用验证正则表达式
    JAVA面试—JDBC
    spring技术的通俗理解
    @RequestMapping 原理(程序如何找到请求的方法的?)
    Java定时任务的几种实现
    什么是分布式系统?
    Java架构师学习路线
    spring boot和SSM开发中有什么区别?
  • 原文地址:https://www.cnblogs.com/porter/p/3706863.html
Copyright © 2011-2022 走看看