Vue数组响应式操作及高阶函数使用代码详解
数组的响应式操作
//this.letters.push('123');//在末尾添加一个元素
//this.letters.pop();//从末尾删除一个元素
//this.letters.unshift('111');//在开端添加一个元素
//this.letters.shift();//从开端删除一个元素
//this.letters.splice(1,2);//从下标为1的元素开始删除两个元素
//this.letters.splice(1,2,'777','888');//从下标为1的元素开始删除两个元素,并插入一个新元素
//this.letters.splice(1,0,'777','888');//在下标为1处插入两个元素
//this.letters.splice(2);//保留前2个元素,其他的删除掉
高阶函数
1、filter过滤函数
filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素。
filter把传入的函数依次作用于每个元素,然后根据返回值是true还是false决定保留还是丢弃该元素。
constnums=[2,3,5,1,77,55,100,200]; letnewArray=nums.filter(function(n){ //小于100就是true,进入newArray数组 returnn<100; }) console.log(newArray);//[2,3,5,1,77,55]
2、map高阶函数
map函数同样会遍历数组每一项,传入回调函数为参数,num是map遍历的每一项,回调函数function返回值会被添加到新数组中
constnums=[2,3,5,1,77,55,100,200]; letnewArray=nums.filter(function(n){ //小于100就是true,进入newArray数组 returnn<100; }) console.log(newArray);//[2,3,5,1,77,55]
3、reduce高阶函数
reduce函数同样会遍历数组每一项,传入回调函数和‘0'为参数,0表示回调函数中preValue初始值为0,回调函数中参数preValue是每一次回调函数function返回的值,currentValue是当前值
constnums=[2,3,5,1,77,55,100,200]; letnew3Array=nums.reduce(function(preValue,currentValue){ //数组为[2,3,5,1,77,55,100,200],则回调函数第一次返回值为0+2=2,第二次preValue为2,返回值为2+3=5,以此类推直到遍历完成 returnpreValue+currentValue; },0);//第二个参数0是preValue的初始值 console.log(new3Array);//443
4、sort排序算法
因为Array的sort()方法默认把所有元素先转换为String再排序,结果'10'排在了'2'的前面,因为字符'1'比字符'2'的ASCII码小。如果不知道sort()方法的默认排序规则,直接对数字排序,绝对栽进坑里!
//要按数字大小排序,我们可以这么写: vararr=[10,20,1,2]; arr.sort(function(x,y){ if(xy){ return1; } return0; });//[1,2,10,20] //如果要倒序排序,我们可以把大的数放前面: vararr=[10,20,1,2]; arr.sort(function(x,y){ if(x y){ return-1; } return0; });//[20,10,2,1]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。