JavaScript_数组

一、 数据结构

数据结构分为: 逻辑结构、存储结构和算法。

(一)存储结构

a. 线性
  • 队列
  • 数组
  • ……
b. 非线性
  • ……

二、 数组基本使用

(一)数组的声明

a. 第一种
// 第一种
var arr1 = [1,2,3,4,5]
console.log(arr1);  // [1,2,3,4,5]
b. 第二种
// 第二种声明
var arr = new Array(10)
// var arr = new Array(10,9,8)
// 当Array()中,只有一个数字参数时,代表着数组的长度,而有 多个时,代表数组的值。
console.log(arr);   // [ , , , , , , , , , ]长度为10

(二)基本属性及用法

a. 数组长度: .length
// length为数组的长度
var arr1 = [1,2,3,4,5]
console.log(arr1.length);   // 5
b. 访问数组数据: [i]
//  i 为数组的下标,通过 [i] 访问数组数据
var arr1 = [1,2,3,4,5]
console.log(arr1[3]);   //   4,注意!从0开始
console.log(arr1[ '0' ]);  // 允许使用字符串的形式,如'0',就是获取第一个( '0' 转换为 1 )
c. 数组的赋值
arr[0] = 10 
console.log(arr[0]); // arr[0] 被赋值为 10

(三)遍历数组

a. for循环
// 数组的遍历
for (var i = 0 ; i< arr1.length ; i++) {
    console.log(arr1[i]);
}
b. for in 迭代器 以下标迭代
// 数组遍历2
var arr = [1,2,3,4,5]
for ( var index in arr ) {  // index,作为变量,可任意取名,是每一个元素的下标
    console.log( arr[index] );
}
c. for of 迭代器 以值迭代
// 遍历数组
var arr = [1,2,3,4,5]
for ( var value of arr ) {  // value,作为变量,可任意取名,是每一个元素的值
    console.log( value );
}

(四)数组方法

a. 增加数据
1) push() 栈方法添加,表示在数组==结尾==添加元素,同时返回数组长度。
var arr = [1,2,5]
console.log(arr);   // 1,2,5,12,这里没写错   push()方法会改变原数组
arr.push(12)
console.log(arr);   // 1,2,5,12
console.log(arr.push(12))   // 4 ,返回数组长度
2) unshift() 队列方法添加,表示在数组==开头==添加元素,同时返回数组长度。
var arr = [1,2,5]
console.log(arr);   // 12,1,2,5 这里没写错   unshift()方法会改变原数组
arr.push(12)
console.log(arr);   // 121,2,5
console.log(arr.push(12))   // 4 , 返回数组长度
b. 减少数据
1) pop() 栈方法删除,表示在数组==结尾==删除元素,同时返回删掉的元素。
var arr = [1,2,5]
console.log(arr);   // 1,2      pop()方法会改变原数组
arr.pop()   
console.log(arr);   // 1,2 
console.log(arr.pop())  //  5,  返回删掉的这个元素
2) shift() 队列方法删除,表示在数组==开头==删除元素,同时返回删掉的元素。
var arr = [1,2,5]
console.log(arr);   // 2,5      shift()方法会改变原数组
arr.shift()
console.log(arr);   // 2,5 
console.log(arr.shift())    //  1,  返回删掉的元素
c. 排序方法
1) reverse() 反转数组,同时也会改变原来的数组!
var arr = [1,2,5]
console.log(arr);   // 5,2,1
arr.reverse()
console.log(arr);   // 5,2,1
2) sort() 升序排列,但默认比ASCii的顺序( 第一位先比,以此类推 ),改变原来数组
var arr= [4,1,7,3,9,2];
console.log(arr.sort());   //从小到大排序,返回排序后的数组
console.log(arr);  // 1,2,4,7,9

eg: sort()可带参数!

// sort()方法中,默认会以ASCii码的数值进行 逐位 比较,所以会产生 ( 2 排在 11 之前 ),所以传入一个函数作为参数
function compare(a, b) {
    if (a <= b) {
        return -1;  //返回0和-1, 表示不交换值
    }
    return 1;   //返回1, 表示会交换值
}
var box = [0, 30 ,21, 5, 77];
var aseBox = box.sort(compare);   //返回升序的数组
console.log(box);   // 0 , 5, 21, 30 ,77
console.log(aseBox);    // 0 , 5, 21, 30 ,77

//  简易写法如下:
arr.sort(function(a,b) {
    return a-b  //  返回a-b,则为从小到大排列,反之,则为从大到小排列; 
})
d.其他操作
1) concat() 进行数组连接,并返回一个新数组
// 追加数据, 创建一个新数组, 不改变原数组
var arr = [2, 3, 4, ‘绿箭侠’, ‘黑寡妇’];
var arr2 = arr.concat(‘美队’, ‘雷神’);
console.log(arr);   // 2, 3, 4, ‘绿箭侠’, ‘黑寡妇'    // 原数组不改变
console.log(arr2);  // 2, 3, 4, ‘绿箭侠’, ‘黑寡妇',‘美队’, ‘雷神’
2) slice() 截取 操作,返回新数组

slice() ---》 [a,b)

// 不修改原数组, 将原数组中的指定区域数据提取出来

var arr = [100,200,300,400,500]
var arr1 = arr.slice( 0,3 ) //  [a,b)   
console.log(arr)    // [100,200,300,400,500] ,不改变原数组
console.log(arr1)   // [100,200,300],返回的新数组
3) splice() 截取 / 插值 操作,返回新数组

splice(索引值,个数)

var arr = [100,200,300,400,500]
var arr1 = arr.splice( 0,3 )    // 0,1,2 ;从0开始,一共截取三个元素
console.log(arr)    // [400,500] ,改变原数组!!
console.log(arr1)   // [100,200,300],返回截取的 新数组

eg:如果是三个参数时:

splice(索引值,个数,需要插入的内容) 插入的内容也放在索引值后面

var arr = [100,200,300,400,500]
var arr1 = arr.splice( 0,3,'我是新来的') 
console.log(arr)    // [ '我是新来的' , 400 , 500 ] ,改变原数组!!
console.log(arr1)   // [100,200,300],返回的新数组
4) join() 连接操作,返回连接后的字符串

连接数组中各个数据,以特定的 '符号' (作为参数传递),将其连接为一个字符串

var arr = [1,2,3]
var arr1 = arr.join(',')    // join()中填写连接方式,该例中,以逗号进行连接
console.log(arr1,arr1.length);      //  '1,2,3'  length:5;返回长度为5的字符串
5) indexOf() 检索数组
// 语法: 数组.indexOf( 数据 ) // !!! 注意,O要大写
// 作用: 查找 数据 在数组中的 索引 位置,若多个,则返回第一个 找不到,则返回 -1 ;
var arr   =   [ 1 , 2  , 1 , 3 ]
console.log( arr.indexOf(1) );  //  0,返回第一次出现的下标
console.log( arr.indexOf(4) );  //  -1,没找到 , 返回 -1 
6) forEach() 遍历数组
// 语法: 数组.forEach(  function (  item  ,  index  ,  arr  ) { }  )
// 作用: 遍历数组,无返回值;
var   arr   =   [  1  ,  2  ,  3   ]
arr.forEach(  function( item , index , arr )  { 
    console.log( item );    // 数组中的每一项
    console.log( index );  //  数组中的索引
    console.log( arr ); //  原数组
}  )

结果:
image.png
7) map() 映射
// 语法: 数组.map(  function (  item  ,  index  ,  arr  ) { }  )
// 作用: 映射数组,返回映射后的新数组;
var   arr   =   [  1  ,  2  ,  3   ]
arr.map(  function(  item  ,  index  ,  arr  )  { 
    return  item * 10   // 返回的值
}  )
console.log(  arr  )    //  [  10  ,  20  ,  30  ]
8) filter() 过滤,返回满足条件的
// 语法: 数组.filter(  function (  item  ,  index  ,  arr  ) { }  )
// 作用: 过滤数组,筛选满足条件的;    返回过滤后的新数组;
var   arr   =   [  1  ,  2  ,  3   ]
arr.filter(  function(  item  ,  index  ,  arr  )  { 
    return  item > 2    // 过滤的条件
}  )
console.log(  arr  )    //  [  3  ]
9) every() Boolean值,每一项都满足时,返回true
// 语法: 数组.every(  function (  item  ,  index  ,  arr  ) { }  )
// 作用: 判断数组 是否 都满足条件;
var   arr   =   [  1  ,  2  ,  3   ]
arr.every(  function(  item  ,  index  ,  arr  )  { 
    return  item > 2    // 判断的条件
}  )
console.log( arr )  //  false,并不是每一项都满足
//  eg2:
arr.every(  function( item , index , arr )  { 
    return  item > 0    // 判断的条件
}  )
console.log( arr )  //  true,每一项都满足!
10) some() Boolean值,当有一项都满足时,返回true
// 语法: 数组.some(  function ( item , index , arr ) { }  )
// 作用: 判断数组 是否 都满足条件;
var   arr   =   [ 1 , 2 , 3 ]
arr.some(  function( item , index , arr )  { 
    return  item > 2    // 判断的条件
}  )
console.log( arr )  //  true,有满足条件的
//  eg2:
arr.some(  function( item , index , arr )  { 
    return  item < 0    // 判断的条件
}  )
console.log( arr )  //  false,  没有满足条件的
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容