中国最全IT社区平台 联系我们 | 收藏本站
华晨云阿里云优惠2

json教程

  • 关于 JSON
  • JSON 教程

    json格式

    JSON解析

    JSON遍历

    JSON调用

    JSON转换

    JSON获取

    JSON字符串

    JSON数组

    解析javascript 数组(以及json元素的添加删除)

    阅读 (2217)

    javasscript删除数组的3种方法


    1,用shift()方法
    shift:删除原数组第一项,并返回删除元素的值;如果数组为空则返回undefined
    var chaomao=[1,2,3,4,5]
    var chaomao.shift()//得到1
    alert(chaomao)//[2,3,4,5]


    2,用pop()方法
    pop:删除原数组最后一项,并返回删除元素的值;如果数组为空则返回undefined
    var chaomao=[1,2,3,4,5]
    var chaomao.pop()//得到5
    alert(chaomao)//[1,2,3,4]
    前面的方法只能操作数组开头和结尾,无法操作中间项,如果要操作中间的项,使用splice方法


    3,用splice方法
    这个方法很强大,可以对数组任意项进行增加,删除,替换操作

    修改操作:
    var chaomao=[1,2,3,4,5]
    chaomao.splice(2,1,8,9)
    alert(chaomao)//1,2,8,9,4,5
    第一个参数是准备操作的数组位置,第二个参数是操作位置后面的数组项数,第三个以后的就是,被替换后的内容
    例子就是表示:从chaomao这个数组位置2开始(也就是值为3的那一项,数组下标从0开始的),位置2后的一项,替换成成8,9
    如果把第二个参数改为2,也就是chaomao.splice(2,2,8,9),也就是说位置2后面的两项换成8,9,打印出来的结果就是1,2,8,9,5,3和4这2两项被换掉了
    这里需要说明的是,被替换的项数不一定要和替换的项数相等,1项可以被换成3项,5项也可以被换成2项,基于这个原理,我们就用这个方法来对数组进行添加和删除操作


    删除操作:
    var chaomao=[1,2,3,4,5]
    chaomao.splice(2,1)
    alert(chaomao)//1,2,4,5
    上面例子中,把chaomao中的位置2后的1项替换成空的,因为后面没有内容,结果可以看到,把3这项删除了


    添加操作:
    var chaomao=[1,2,3,4,5]
    chaomao.splice(2,0,8,9)
    alert(chaomao)//1,2,8,9,3,4,5
    上面例子中,把chaomao中位置2后的0项换成8,9,也就等于添加了两项
    其实,删除和添加操作都只是splice修改方法的两种衍生罢了


    javasscript删除对象的方法
    js中删除对象元素用delete操作符
    我们来看看一个例子

    代码如下:
    var p ={
    "name": “chaomao”,
    "age":45,
    "sex":"male"
    };
    delete p.name
    for(var i in p){
    console.log(i);//输出age,sex,name项已经被删除了
    }
    
    添加json元素的方法
    var json = {}; // 如果json已经定义就跳过
    json[text] = value;
    json.text2 = value2;  // 此时text2必须符合变量名标准,否则得使用数组方式赋值
    
    代码如下:
    var json = {}; // 如果json已经定义就跳过
    json[text] = value;
    json.text2 = value2;  // 此时text2必须符合变量名标准,否则得使用数组方式赋值
    

    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);
    
    结果都为:'空闲闲置期'
    关闭
    程序员人生