js中数组、map初始化和赋值数组
var m = new Array();//或
var n = [];
var m = new Array(2);  //⼀个值表⽰数组length
var m = new Array(2,3,4,5); //多个值表⽰数组赋值
m[0] = 2;  m[1] = 3;  m[2] = 4;
// 数组增加元素push()
m.push(6);
1. 项⽬1
unshift:将参数添加到原数组开头,并返回数组的长度
pop:删除原数组最后⼀项,并返回删除元素的值;如果数组为空则返回undefined
push:将参数添加到原数组末尾,并返回数组的长度
concat:返回⼀个新数组,是将参数添加到原数组中构成的
splice(start,deleteCount,val1,val2,…):从start位置开始删除deleteCount项,并从该位置起插⼊val1,val2,…
reverse:将数组反序
sort(orderfunction):按指定的参数对数组进⾏排序
slice(start,end):返回从原数组中指定开始下标到结束下标之间的项组成的新数组
2. 详细:
1、数组的创建
var arrayObj = new Array(); //创建⼀个数组
var arrayObj = new Array([size]); //创建⼀个数组并指定长度,注意不是上限,是长度
var arrayObj = new Array([element0[, element1[, …[,elementN]]]]); 创建⼀个数组并赋值。
要说明的是,虽然第⼆种⽅法创建数组指定了长度,但实际上所有情况下数组都是变长的,也就是说即使指定了长度为5,仍然可以将元素存储在规定长度以外的,注意:这时长度会随之改变。
2、数组的元素的访问
var testGetArrValue=arrayObj[1]; //获取数组的元素值
arrayObj[1]= “这是新值”; //给数组元素赋予新的值
3、数组元素的添加
arrayObj. push([item1 [item2 [. . . [itemN ]]]]);//将⼀个或多个新元素添加到数组结尾,并返回数组新长度
arrayObj.unshift([item1 [item2 [. . . [itemN ]]]]);//将⼀个或多个新元素添加到数组开始,数组中的元素⾃动后移,返回数组新长度
arrayObj.splice(insertPos,0,[item1[, item2[, . . .[,itemN]]]]);//将⼀个或多个新元素插⼊到数组的指定位置,插⼊位置的元素⾃动后移,返回""。
4、数组元素的删除
arrayObj.pop(); //移除最后⼀个元素并返回该元素值
arrayObj.shift(); //移除最前⼀个元素并返回该元素值,数组中元素⾃动前移
arrayObj.splice(deletePos,deleteCount);//删除从指定位置deletePos开始的指定数量deleteCount的元素,数组形式返回所移除的元素
5、数组的截取和合并
arrayObj.slice(start, [end]); //以数组的形式返回数组的⼀部分,注意不包括 end 对应的元素,如果省略end 将复制 start 之后的所有元素
6、数组的拷贝
arrayObj.slice(0); //返回数组的拷贝数组,注意是⼀个新的数组,不是指向
7、数组元素的排序
arrayObj.sort(); //对数组元素排序,返回数组地址
8、数组元素的字符串化
arrayObj.join(separator); //返回字符串,这个字符串将数组的每⼀个元素值连接在⼀起,中间⽤separator 隔开。
js合并两个数组toLocaleString 、toString 、valueOf:可以看作是join的特殊⽤法,不常⽤
map
map.obj=obj2; //添加⼀个key为obj,值为obj2
map[obj] = obj2; //添加⼀个key为obj,值为obj2
var map ={
key1:'abc',
key2:'def'
};
// 这样定义即可。动态赋值如下:
map.key3 = '12';
// 如果key也是动态的,则如下处理
var key = 'key4';
map[key] = '34';
注意:在JavaScript语⾔中,key的值只能是字符串,不能是其它的。map遍历
for(var key in jsonData){
console.log("属性:" + key + ",值:"+ jsonData[key]);
}
/
/ 判断map中是否包含某个key值
if(map.hasOwnProperty('key')){
var value = map[key];
}

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。