JS随写:A组rray数

Array数组

创建数组的两种方式:

  1. 使用Array构造函数 var colors = new Array() , new 操作符可省略
    给构造函数传递一个值的话,若为数值,则该值为新数组的长度;若为其他类型,则该值为新数组的第一个元素,且数组长度为1。
    var colors = new Array(3); //创建一个包含3项的数组,值都为undefined
    var colors = new Array("liyang"); //创建一个包含1项,即字符串'liyang'的数组
    根据此特性创建一个重复某字符串n次的方法:
function repeatString(str,n){
        return new Array(n+1).join(str);   //创建一个长度为n+1的空数组,使用str来连接这个空数组的元素,即undefined
}
repeatString("a",4);    // 返回  "aaaa"
repeatString("3",3);   //返回 "333"
  1. 使用数组字面量表示法
    var colors = ['red','yellow','green'];
    var values = [1,2,]; //不推荐,IE8及以下会视为长度为3,最后一个值为undefined
    var options = [,,,]; //不推荐,IE8会视为长度为4,值都是undefined

直接给Array的length赋一个新的值会导致Array大小的变化;
Array可以通过索引把对应的元素修改为新的值;
如果通过索引赋值时,索引超过了范围,同样会引起Array大小的变化

检测数组

  1. value instanceof Array 执行环境会对其判断有影响
  2. ECMAScript5新增的方法 Array.isArray() 来确定某个值到底是不是数组

转换方法

所有对象都有 toLocaleString()、toString()和valueOf()方法,数组的调用如下:

  1. toString():返回由数组中每个值的字符串形式拼接而成的一个以逗号分隔的 字符串
  2. toLocaleString():同样返回一个逗号分隔的字符串,不同在于会调用数组每一项的toLocaleString()方法,而不是toString()方法;
  3. valueOf(): 返回数组;

shift,unshift和push,pop

  1. shift() 方法删除 Array 的第一个元素,返回的是删掉的元素
  2. unshift() 方法向 Array 的头部添加若干值,返回的是新数组的长度
  3. push() 方法向 Array 的尾部添加若干值,返回的是新数组的长度
  4. pop() 方法删除 Array 的最后一个元素,返回的是删掉的元素
var arr = [1,2,3,4];
arr.shift();  // 返回'1'
arr; // [2,3,4]
arr.unshift('a','b');  //返回 5
arr;  //['a','b','2','3','4']

arr.push('c','d');  //返回 7
arr;  //['a','b','2','3','4','c','d']
arr.pop();  //返回 'd'
arr;  //['a','b','2','3','4','c']

reverse和sort

  1. reverse() 方法用于反转数组项的顺序
  2. sort() 方法用于排序数组,默认按照升序排序
    sort() 方法会调用每个数组项的 toString() 方法,然后比较字符串进行排序,可以接受一个比较函数作为参数。
var arr = [13,15,5,2,6];
arr.sort();
arr;  //[13,15,2,5,6]
arr.sort(function(a,b){
    return a - b;  //升序
});
arr;  //[2,5,6,13,15]

arr.sort(function(a,b){
    return b - a;  //降序
});
arr;  //[15,13,6,5,2]

slice和splice

  1. slice() 方法截取数组的部分元素,根据索引来截取。对应字符串的 substring() 方法
  2. splice() 方法可以从指定的索引处开始删除n个元素,然后再从该位置添加m个元素,是数组的万能方法
var arr = ['red','yellow','green','blue'];
arr.slice(1,3);  //从1开始截取到3,不包括3。返回截取的数组['yellow','green']
arr;  //数组本身不变:['red','yellow','green','blue']

var arr2 = ['red','yellow','green','blue'];
arr2.slice(2);  //从索引2开始到结束。['green','blue']
arr2;  //数组本身不变:['red','yellow','green','blue']

var arr3 = ['red','yellow','green','blue'];
var copy = arr3.slice();  //不传值相当于复制数组
copy;  //返回:['red','yellow','green','blue']
copy === arr;  // false

var arr4 = ['red','yellow','green','blue'];
arr4.slice(1,-1);  // ['yellow','green']  -1索引指最后一个元素,-2指倒数第二个

---------------

var arr1 = ['a','b','c','d'];
//从索引2开始删除1个元素,然后再添加两个元素
arr1.splice(2,1,'red','yellow');  //返回删除的元素['c']
arr1;  // ['a','b','red','yellow','d']
//只删除,不添加
arr1.splice(1,2);  //返回删除的元素数组 ['b','red']
arr1;  //  ['a','yellow','d']
//只添加,不删除
arr1.splice(1,0,'green');  //返回空[],因为没有删除元素
arr1;   // ['a','green','yellow','d']  注意是在索引1的<前面>添加新元素

concat和join

  1. concat() 方法把当前的Array和另一个Array连接起来,返回一个新的数组
  2. join() 方法把当前Array的每个元素都用指定的字符串连接起来,然后返回连接后的字符串
var arr = ['a','b','c'];
var added = arr.concat([1,2,3]);
added;  // ['a','b','c',1,2,3]
arr;  //['a','b','c']  原数组并未改变
arr.concat([1,2],3);  // ['a','b','c',1,2,3] 数组元素会被拉平
arr.concat([1,2,[3,4]]);  // ['a','b','c',1,2,[3,4]] 多重数组不会被拉平

var arr2 = ['a','b','c',1,3]
arr.join('-');   //返回字符串 a-b-c-1-3
arr;  //['a','b','c',1,3]  原数组并未改变
arr.toString();  //返回字符串 a,b,c,1,3
arr.join(',');  //返回字符串 a,b,c,1,3 同toString()方法

indexOf和lastIndexOf

两者都接收两个参数:要查找的项和表示查找地点的索引(可选);indexOf()从数组开头开始向后查找,lastIndexOf()从数组的末尾向前查找。若查找的项没找到则返回-1

var arr = [1,2,3,2,1];
arr.indexOf(2);  //1
arr.indexOf(99);  //-1
arr.indexOf(1,1);  //4
arr.indexOf(1,-3);  //4
arr.indexOf(2,-1);  //-1
arr.lastIndexOf(2); //3
arr.lastIndexOf(2,-2)  //3
arr.lastIndexOf(2,-3)  //1

数组的迭代方法

ECMAScript5定义了5个数组的迭代方法,每个方法都接收2个参数:要在每一项上运行的函数和运行该函数的作用域对象-影响this的值(可选)。 函数会接收3个参数:数组项的值item,item项的索引index和该数组对象本身。

every()和some()

every() :数组中每一项运行函数,都返回true,才返回true。
some() :数组中每一项运行函数,有一项返回true,就返回true。

filter()

数组中每一项运行函数,返回 函数运行为true的项 组成的数组。

map()

数组中每一项运行函数,返回 每次调用函数返回的值 组成的数组,跟原数组一一对应。

forEach()

对数组中每一项运行函数,没有返回值

数组的归并方法

reduce()和reduceRight()

ECMAScript5定义了2个数组的归并方法,每个方法都接收2个参数:在每一项调用的值和作为归并的初始值(可选)。 函数会接收4个参数:前一个值,当前值,项的索引和数组对象本身。这个函数的返回值会作为第一个参数自动传个下一项。 第一次迭代发生在数组第二项上,因此第一个参数是数组第一项,第二个参数是数组第二项。

var values = [1,2,3,4,5];
var sum = values.reduce(function(prev,cur,index,array){
    return prev + cur;
});
sum;  // 15

第一次执行回调函数,prev是1,cur是2。第二次执行,prev是返回值3,cur是第三项3。过程直至数组最后一项。

var values = [1,2,3,4,5];
var sum = values.reduce(function(prev,cur,index,array){
    return prev + cur;
},6);
sum;  // 21

若传入第二个参数作为初始值(可为任意值),则第一次prev是6,cur是数组第一项1。

reduceRight()是反过来从最后开始执行。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,226评论 0 4
  • 由于最近都在freecodecamp上刷代码,运用了很多JavaScript数组的方法,因此做了一份关于JavaS...
    2bc5f46e925b阅读 1,969评论 0 16
  • 记得前几天,一个师弟让我替他宣传一下他妈妈自己做的芝麻糊。我就给发到朋友圈了。没想到,短短的一星期,师弟已经寄...
    Mr_Zoul阅读 219评论 0 0
  • 不管是个人家庭还有国家,都需要明确的目标,前进的方向,行为的理念 看看这个世界怎么样,春夏秋冬,山川河岳,花鸟虫鱼...
    阳光果粒_d05b阅读 194评论 0 0
  • 商风声阅读 86评论 0 0