直接在JS里创建JSON数据然后遍历使用

直接在JS里创建JSON数据,然后遍历使用~
创建代码如下:(创建的是JSON对象)

var YearSelect = {}; 
var Year = 2014; 
var DateOption; 
for (var i = Year; i < Year + 12; i++) { 
DateOption = {Year:i, Month:i-Year+1}; 
/ alert(DateOption.Year) 
YearSelect[i] = DateOption; 
}

这里是创建一个JSON对象,包括了年份和月份的数据。
我为什么创建JSON对象,是因为我对JSON对象比较熟悉。php后台返回的也是json对象。
json对象没有length属性~~
所以遍历的话要:

for(var key in YearSelect){ 
alert(YearSelect[key].Year); 
alert(YearSelect[key].Month); 
}

这样就可以了~
记住一定要分辨好json的对象和数组~不然就一直是undenfined

js数组如何添加json数据及js数组与json的区别

下面给大家介绍js数组添加json数据的两种方式。
// 第一种方式

personInfo
: [],
for(var i = 0; i < _STAGE.passengerInfoArray.length; i++){
var name = _STAGE.passengerInfoArray[i];
var person = {v:name, text:name};
this.personInfo.push(person);
}

// 第二种方式

var passengerInfo = {};
passengerInfo.psgTypeDesc = psgTypeDesc;
passengerInfo.flightPrice = flightPrice;
_STAGE.passengerInfoArray.push(passengerInfo);

js数组与 json 的区别

一、数组

1. 定义一维数组:var s1=new Array();
                      s1=[1,2,3,4]或者s1[0]=1,s1[1]=2,s1[3]=3,s1[4]=4;
                      alert(s1[0]);
                      结果为1;

2. 定义二维素组:var s1=new Array();
                      var s1=[[3,1],[2,3,4],3,[4,5,6,7,8]];
                      alert(s1[1][0]);
                      结果为2;

二、定义json对象

1. json对象       

var status_process = {
    " name5" : 闲置期,
    "name1" : 播种期,
    "name2" : 苗期,
    "name3" : 生长期,
    "name4" : 采收期
   }    
  alert(status_process);

结果为:Object:Object;

2. json字符串

所谓json字符串,是指该字符串变量的值与json的格式相同,但是不是json对象,比如:

var s1="{";
var s2 = " name5 : 闲置期,  name1 : 播种期,name2 : 苗期,name3 : 生长期,name4 : 采收期";
var s3="}";
var status_process=s1+s2 +s3;

虽然status_process的值符合json对象的格式,但是它不是对象,只是一个字符串(是拼凑出来的);    

将字符串转换为json对象使用函数eval,eval(“(” + status_process+ “)”);

结论:从后台传入到前台的是json字符串,不是真正的json对象,因此需要使用eval函数转换。
  

3. json对象的使用       

var status_process = {
      name5 : 闲置期,
     name1 : 播种期,
     name2 : 苗期,
      name3 : 生长期,
      name4 : 采收期
     };
     alert(status_process["name5"]);
     alert(status_process.name5);

两个都为:闲置期

  

4. json二维对象       

var status_process = {
 name5 : {name3:空闲闲置期},
 name1 : 播种期,
 name2 : 苗期,
 name3 : 生长期,
 name4 : 采收期
};
alert(status_process["name5"]["name3"]);
alert(status_process.name5.name3);

结果都为:空闲闲置期

作者:andy,如若转载,请注明出处:https://www.web176.com/json/15063.html

(0)
打赏 支付宝 支付宝 微信 微信
andy的头像andy
上一篇 2023年4月3日
下一篇 2023年4月3日

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注