JS数组与JS对象

首先JS的Array继承自Object,JS数组不像PHP或者其它一些语言一样拥有真正的字符串下标,当我们试图为一个JS数组添加字符串下标的时候,其实就相当于为该数组对象添加了一个属性,属性名称就是我们所谓的“字符串下标”。

var arr=new Array();
arr['name']='张三';
arr['age']=28;
console.log(arr);

如上图:输出空数组,length为0,属性age为28,属性name为张三,由于为数组对象添加属性不会影响到同为该对象属性的length的值,因此length始终为零。如果要使用由“字符串下标”组成的数组,将其声明为一个Object类型的对象即可。

var obj=new Object();
obj['name']='张三';
obj['age']=28;
console.log(obj);
//或者点形式
var obj=new Object();
obj.name='张三';
obj.age=28;
console.log(obj);


如上图:输出对象
JS对象属性的中括号形式与点形式比较:
中括号形式总是能代替点形式,但点形式却不一定能全部代替中括号形式。
中括号形式可以用字符串变量的值作为属性名,点形式不能。
中括号形式可以用纯数字为属性名,点形式不能。
中括号形式可以用JS的关键字和保留字作为属性名,点形式不能。

var obj=new Object();
var s='name';
obj[s]='张三';//变量值
obj[10]=28;//数字
obj['var']='AA';//保留字
console.log(obj);


如上图:属性分别为数字10,变量值name,保留字var

var arr=new Array();
arr['name']='张三';
arr['age']=28;
arr[10]=500;
console.log(arr);



如上图:显示数组长度为11,其中10个空的未显示,这里10并没有成为该数组对象的属性,由于JS数组下标值的范围为0到2的32次方。对于任意给定的下标值,如果不在此范围内,js会将它转换为一个字符串,并将该下标对应的值作为该数组对象的一个属性值而不是数组元素,arr['name']中的name下标就不在此范围,故被当作数组对象arr的属性。如果该下标值在合法范围内,则无论该下标值是数字还是数字字符串,都一律被转化为数字使用,即 array["10"] = 0 和 array[10] = 0 执行的是相同的操作。

将JS对象转数组:

function objToArr(obj) {
        var arr=[];
        //下标从0开始的,防止下标不一致造成数组空元素
        var k=0;       
        $.each(obj, function(i) {
            arr[k]=obj[i];
            k++;
        });
        return arr;
}

 

你可能感兴趣的:(前端开发,其他)