JS基础 - 数组

目录

1.创建

2.数组的访问

3.数组的遍历

4.数组的检测

5.数组序列化

6.数组的API


 

数组
引用数据类型

作用:用来保存多个值,可以保存任意数据类型
数组是以中括号[]为界限,值与值之间使用逗号分隔,数组长度属性length,数组长度是动态的

1.创建

    1)数组字面量

  var arr = [1,2,3,4]
  //arr.length  => 4
  var arr = [123,"hello",true,null];

    2)构造函数

var arr = [元素1,元素2....元素N];
var arr = [123,"hello",true,null];

        var arr = new Array()  =>空数组[] =>间接Object
        arr.length  => 0
        传递一个参数:给数组指定一个数组长度 var arr1 = new Array(5)  ,arr.length = 5
        传递多个参数:相当于初始化数组  var arr1 = new Array(1,2) => [ 1, 2 ]

2.数组的访问


    数组下标,数组下标是从0开始的,一直到数组的长度-1,如果访问下标超过数组长度,不报错,但是会返回undefined

    arr[i]
   

    arr[0]  =>1
    arr[1]  =>2
    arr[4]  =>undefined  溢出
    var arr = ['tom',12]               arr[0]    0:'tom',1:12
    arr[2] = true
    var obj = {name:'tom',age:12}      obj.name || obj['name']
    obj.gender = '男'


    给数组添加项:arr[下标] = 值(任意数据类型)
    删除数组项:arr.length = arr.length - 3

修改length

        如果修改后的length大于原长度,则多出的部分会空出来

        如果修改后的length小于原长度,则原数组中多出的元素会被删除

//向数组的最后一个位置添加元素
 arr[arr.length] = 70;

3.数组的遍历

1)forEach

数组.forEach(function(value , index , obj){  
  //value:正在遍历的元素
  //index:正在遍历元素的索引
  //obj:被遍历对象
});
var arr = ["sun","zhu","sha"];
   arr.forEach(function(value,index,obj)){
   console.log("value = "+value);
}

2)for循环

        <script type="text/javascript">
			//创建数组
			var arr = ["sun","zhu","sha"];
			
			//遍历数组
			for(var i=0;i<arr.length;i++){
				console.log(arr[i]);
			}
		</script>


4.数组的检测

//使用typeof检查数组时,会返回object
console.log(typeof arr);     //object


    instanceOf      arr(目标) instanceOf Array =>是数组,返回true,不是数组,返回false
    Array.isArray(arr)  

5.数组序列化

    toString()  默认将数组的每一项使用“,”隔开,以字符串的形式输出
    join(参数)      将数组的每一项以想要的符号分开,以字符串的方式输出

var arr = [1,2,3,4,5,6,7]
//toString()
console.log(arr.toString())   //1,2,3,4,5,6,7

//join()
console.log(arr.join('~'))     //1~2~3~4~5~6~7

6.数组的API

var arr = ["sun","zhu","sha"];


    栈、队列方法:改变原数组
        栈(先进后出,后进先出)
            pop()    移除数组中的最后一个项并且返回该项,同时将数组的长度减一

var result = arr.push("tang","zhi","bai");
console.log(arr);  //Array(6) [ "sun", "zhu", "sha", "tang", "zhi", "bai" ]
console.log("result = "+result);  //6


            push()     可接受任意类型的参数,将它们逐个添加到数组的末尾,并返回数组的长度

arr.pop();
console.log(arr);  //Array(5) [ "sun", "zhu", "sha", "tang", "zhi" ]


        队列(先进先出,后进后出)
            shift()      移除数组中的第一个项并且返回该项,同时将数组的长度减一

arr.shift();
console.log(arr);   //Array(5) [ "sun", "zhu", "sha", "tang", "zhi" ]


            unshift()     在数组的前端添加任意个项,并返回数组的长度

arr.unshift("niu");
console.log(arr);   //Array(6) [ "xin", "sun", "zhu", "sha", "tang", "zhi" ]


    
    排序
        reverse()  反转数组项的顺序,改变原数组

arr.reverse();


        sort()
            默认排序:该方法会调用每个数组项的toString() 方法,然后按照字符序列排序
            自定义排序:
                a.该方法可以接受一个比较函数作为参数,比较函数有两个参数
                b.如果第一个参数位于第二个参数之前,返回负数
                c.如果第一个参数位于第二个参数之后,返回正数

var arr = [2,15,27,55,39,13,4,6]
var a = arr.sort(function(a,b){
    if(a>b){
         return 1
     }else if(a<b){
        return -1
     }else{
         return 0
     }
    //return a-b  升序
    //return b-a   降序
})
console.log(a)

    截取方法
        concat

            数组的拼接       不改变原数组           返回副本

var arr = ["sun","zhu","sha"];
var arr2 = ["baigu","yutu","zhihzu"];
var arr3 = ["baigu","yutu","zhihzu"];
			
var result = arr.concat(arr2,arr3,"niu","tie");
console.log(result);    

        slice

            截取数组         不改变原数组          截取到的数组

            slice(a)        从a开始截取,一直到数组结束

            slice(a,b)      从a开始截取,一直到第b项,但是不包含第b项 => [a,b)

        splice

            删除   splice(a,b)  从第a项开始删除,删除b项   返回删除掉的项

            插入   splice(a,0,b,c,d)  从第a项开始,插入,插入b,c,d  返回空数组

            替换   splice(a,b,i1,i2,i3) 从第a项开始,删除b项,将i1,i2,i3插入

    
    索引方法
        indexOf()  
            从数组开头向后查找,使用全等操作符,找不到该元素返回-1。
            第一个参数为要查找的项,第二个参数(可选)为索引开始位置
        lastIndexOf()  
            从数组末尾向前查找,使用全等操作符,找不到该元素返回-1。
            第一个参数为要查找的项,第二个参数(可选)为索引开始位置

    迭代方法
        参数: 每一项上运行的函数,运行该函数的作用域对象(可选)
        every()  
            对数组中的每一元素运行给定的函数,如果该函数对每一项都返回true,则该函数返回true
        some()  
            对数组中的每一运行给定的函数,如果该函数对某一项返回true,则返回true
        filter()
            对数组中的每一项运行给定的函数,会返回满足该函数的项组成的数组
        map()
            对数组中的每一元素运行给定的函数,返回每次函数调用的结果组成的数组
        forEach()
            对数组中的每一元素运行给定的函数,没有返回值,常用来遍历元素  

var arr = [1,2,5,7,8,6]
 var r = arr.every(function(item,index,arr){
    return item>2
 })

 var r2 = arr.some(function(item,index,arr){
     return item>2
 })

var r3 = arr.filter(function(item,index,arr){
    return item>4
})

var r4 = arr.map(function(item,index,arr){
    return item*2
})

var r5= []
arr.forEach(function(item,index,arr){
    //console.log(item);
    r5.push(item)
})

 console.log(r)    //false  所有的元素都大于2不对
 console.log(r2)   //true   有大于2的元素
 console.log(r3);   //[ 5, 7, 8, 6 ]  返回大于4的元素
 console.log(r4);   //[ 2, 4, 10, 14, 16, 12 ]
 console.log(r5);
 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值