Web/03-JavaScript基础/15-数组的四个基本方法&数组的遍历.md
2019-02-03 20:30:09 +08:00

8.0 KiB
Raw Blame History

前言

数组的四个基本方法如下:

方法 描述 备注
push() 向数组的最后面插入一个或多个元素,返回结果为该数组新的长度 会改变原数组
pop() 删除数组中的最后一个元素,返回结果为被删除的元素 会改变原数组
unshift() 在数组最前面插入一个或多个元素,返回结果为该数组新的长度 会改变原数组
shift() 删除数组中的第一个元素,返回结果为被删除的元素 会改变原数组

遍历数组的方法如下:

数组的四个基本方法(数组元素的添加和删除)

push()

push():向数组的最后面插入一个或多个元素,返回结果为该数组新的长度

语法:

	数组的新长度 = 数组.push(元素);

代码举例:

	var arr = ["王一", "王二", "王三"];

	var result1 = arr.push("王四"); // 末尾插入一个元素
	var result2 = arr.push("王五", "王六"); // 末尾插入多个元素

	console.log(result1); // 打印结果4
	console.log(result2); // 打印结果6
	console.log(JSON.stringify(arr)); // 打印结果:["王一","王二","王三","王四","王五","王六"]

pop()

pop():删除数组中的最后一个元素,返回结果为被删除的元素

语法:

	被删除的元素 = 数组.pop();

代码举例:

	var arr = ["王一", "王二", "王三"];

	var result1 = arr.pop();

	console.log(result1); // 打印结果:王三
	console.log(JSON.stringify(arr)); // 打印结果:["王一","王二"]

unshift()

unshift():在数组最前面插入一个或多个元素,返回结果为该数组新的长度。插入元素后,其他元素的索引会依次调整。

语法:

	数组的新长度 = 数组.unshift(元素);

代码举例:

	var arr = ["王一", "王二", "王三"];

	var result1 = arr.unshift("王四"); // 最前面插入一个元素
	var result2 = arr.unshift("王五", "王六"); // 最前面插入多个元素

	console.log(result1); // 打印结果4
	console.log(result2); // 打印结果6
	console.log(JSON.stringify(arr)); // 打印结果:["王五","王六","王四","王一","王二","王三"]

shift()

shift():删除数组中的第一个元素,返回结果为被删除的元素

语法:

	被删除的元素 = 数组.shift();

代码举例:

	var arr = ["王一", "王二", "王三"];

	var result1 = arr.shift();

	console.log(result1); // 打印结果:王一
	console.log(JSON.stringify(arr)); // 打印结果:["王二","王三"]

数组的遍历

遍历数组即:获取并操作数组中的每一个元素。

数组迭代方法包括every()、filter()、forEach()、map()、some()

PS这几个方法不会修改原数组

语法格式:

数组/boolean/无 = 数组.every/filter/forEach/map/some(
                            function(element,index,arr){
                                            程序和返回值;

有了这几种方法就可以替代一些for循环了。下面依次来介绍。

for循环 遍历

举例:

        var arr = ["生命壹号","许嵩","永不止步"];
        for(var i = 0;i<arr.length;i++){
            console.log(arr[i]);  // arr[i]代表的是数组中的每一个元素i
        }

        console.log(arr);

打印结果:

forEach() 遍历

forEach() 这种遍历方法只支持IE8以上的浏览器。IE8及以下的浏览器均不支持该方法。所以如果需要兼容IE8则不要使用forEach改为使用for循环来遍历即可。

forEach()方法需要一个函数作为参数。这种函数,是由我们创建但是不由我们调用的,我们称为回调函数。

数组中有几个元素,该回调函数就会执行几次。执行完毕后,浏览器会将遍历到的元素。

回调函数中传递三个参数:

  • 第一个参数,就是当前正在遍历的元素

  • 第二个参数,就是当前正在遍历的元素的索引

  • 第三个参数,就是正在遍历的数组

代码举例:

	var arr = ["王一", "王二", "王三"];

	arr.forEach(function(item, index, obj) {
	console.log("item:" + item);
	console.log("index:" + index);
	console.log("obj:" + obj);
	console.log("----------");
	});

打印结果:

item:王一
index:0
obj:王一,王二,王三
----------

item:王二
index:1
obj:王一,王二,王三
----------

item:王三
index:2
obj:王一,王二,王三
----------

map()方法

解释:对数组中每一项运行回调函数,返回该函数的结果,组成的新数组(返回的是加工之后的新数组)。

比如说有一个已知的数组arr1我要求让arr1中的每个素加10这里就可以用到map方法。举例

    var arr1 = [1, 3, 6, 2, 5, 6];

    var arr2 = arr1.map(function (item, index) {
        return item + 10;  //让arr1中的每个元素加10

    })
    console.log(arr2);

打印结果:

举例2

    var arr1 = ["千古", "宿敌", "南山忆", "素颜"];

    var arr2 = arr1.map(function (element, index, array) {
        return element + "vae";  //给arr1中所有的元素增加字符串"vae"放到arr2中。
    });

    console.log(arr1);
    console.log(arr2);

结果:

filter

语法:

    Array.prototype.filter(function(item, index){})

解释对数组中每一项运行回调函数该函数返回结果是true的项将组成新的数组返回值就是这个新的数组

举例1找出数组 arr1 中大于4的元素返回一个新的数组。代码如下

    var arr1 = [1, 3, 6, 2, 5, 6];

    var arr2 = arr1.filter(function (item, index) {
        return item > 4; //将arr1中大于4的元素返回
    })
    console.log(arr2);

打印结果:

举例2

    var arr1 = ["千古", "宿敌", "南山忆", "素颜"];

    var arr2 = arr1.filter(function (element, index, array) {
        if (element.length > 2) { //arr1中的元素如果是长度超过2个字符的我就把它放到arr2中去
            return true;
        }
        return false;
    });
    console.log(arr1);
    console.log(arr2);

结果:

every()方法

解释对数组中每一项运行回调函数如果都返回trueevery就返回true如果有一项返回false则停止遍历此方法返回false。

注意every()方法的返回值是boolean值参数是回调函数。

举例:

    var arr1 = ["千古", "宿敌", "南山忆", "素颜"];
    var bool1 = arr1.every(function (element, index, array) {
        if (element.length > 2) {
            return false;
        }
        return true;
    });
    console.log(bool1);  //输出结果false。只要有一个元素的长度是超过两个字符的就返回false

    var arr2 = ["千古", "宿敌", "南山", "素颜"];
    var bool2 = arr2.every(function (element, index, array) {
        if (element.length > 2) {
            return false;
        }
        return true;
    });
    console.log(bool2);  //输出结果true。因为每个元素的长度都是两个字符。

some()方法

解释对数组中每一项运行回调函数只要有一项返回true则停止遍历此方法返回true。

我的公众号

想学习代码之外的技能?不妨关注我的微信公众号:千古壹号idqianguyihao)。

扫一扫,你将发现另一个全新的世界,而这将是一场美丽的意外: