JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()

JavaScript 之 常用迭代方法forEach、filter、map、reduce

  • 1. for、forEach
    • 1.1 for 遍历的3种写法
    • 1.2 forEach + 回调函数 遍历
    • 1.3 forEach + 箭头函数 遍历
  • 2. filter()
    • 2.1 介绍
    • 2.2 例子1——简单过滤
    • 2.3 例子2——在修改数组时 filter() 方法的行为
    • 2.4 例子3——在数组中搜索
  • 3. map()
    • 3.1 介绍
    • 3.2 例子1——求数组中每个元素的2倍
    • 3.3 例子2——使用 map 重新格式化数组中的对象
  • 4. reduce()
    • 4.1 介绍
    • 4.2 例子1——数组元素求和
    • 4.3 例子2——求对象数组中某属性值的总和
    • 4.4 例子3——展平嵌套数组
    • 4.5 例子4——统计对象中值的出现次数
    • 4.6 例子5——数组去重

1. for、forEach

1.1 for 遍历的3种写法

  • 代码如下:
    var array = [66,77,88];
    
    for(var i =0;i<array.length;i++){
    	console.log(array[i]);
    }
    
    console.log("\n============")
    
    for(var i in array){
    	console.log(array[i]);
    }
    
    console.log("\n============")
    
    for(var item of array){
    	console.log(item);
    }
    
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第1张图片
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第2张图片

1.2 forEach + 回调函数 遍历

  • 如下:

    	  var array = [66,77,88];
    
          console.log("\n=====1.1=======\n\n")
    
          array.forEach(function(value){
              console.log(value);
          });
    
          console.log("\n====1.2========\n\n")
    
          array.forEach(function(value,index){
              console.log(`${index}--->${value}`);
          });
    
    
    	  function Dog(name,age){
    		  this.name = name;
    	  	  this.age = age;
    	  }
    	  var d1 = new Dog("麦兜",3);
    	  var d2 = new Dog("贝塔",2);
    	
    	  var dogArray = [d1,d2];
    
          console.log("\n\n\n=====2.1=======\n\n\n")
    
          dogArray.forEach(function(dog){
              console.log(dog);
          })
    
          console.log("\n=====2.2=======\n\n")
    
          dogArray.forEach(function(dog,index){
              console.log(index + '---->' + JSON.stringify(dog));
          })
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第3张图片

1.3 forEach + 箭头函数 遍历

  • 代码简洁很多,如下:

    var array = [66,77,88];
    
    console.log("\n=====1.1=======\n\n")
    
    array.forEach(value=>console.log(value));
    
    console.log("\n====1.2========\n\n")
    
    array.forEach((value,index)=>{
        console.log(`${index}------${value}`);
    })
    
    
    function Dog(name,age){
    	this.name = name;
    	this.age = age;
    }
    var d1 = new Dog("麦兜",3);
    var d2 = new Dog("贝塔",2);
    
    var dogArray = [d1,d2];
    
     console.log("\n\n\n=====2.1=======\n\n\n")
    
     dogArray.forEach(dog=>console.log(dog))
    
     console.log("\n=====2.2=======\n\n")
    
     dogArray.forEach((dog,index)=>console.log(index + '---' + JSON.stringify(dog)))
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第4张图片

2. filter()

2.1 介绍

  • 简介
    filter() 方法创建给定数组一部分的浅拷贝,其包含通过所提供函数实现的测试的所有元素。
  • 语法
    filter(callbackFn)
    filter(callbackFn, thisArg)
    
  • 参数、返回值
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第5张图片
  • 描述
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第6张图片
  • 参考官网:
    官网——Array.prototype.filter().

2.2 例子1——简单过滤

  • 代码如下:
    const array = [66,77,88];
    
    //1. 箭头函数回调
    const newArray_1 = array.filter(arr => arr > 70);
    
    //2. 匿名函数回调
    const newArray_2 = array.filter(function(arr){
        return arr > 70;
    });
    
    //3. 普通函数回调
    function myFilter(val){
        if(val > 70){
            return true;
        }else{
            return false;
        }
    }
    const newArray_3 = array.filter(myFilter);
    
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第7张图片

2.3 例子2——在修改数组时 filter() 方法的行为

  • 代码如下:

    console.log("\n\n====1. 排除第一个元素=====\n\n");
    
     const numArray_1 = [6,7,8];
    
     const new_numArray_1 = numArray_1.filter((item,index,array)=>{
         array[index+1] += 10; //修改的是下一个元素,影响了初始数组,但是数组中第一个数据不动,其余+10
         return item > 10; //除了第一个元素,其余判断时都已经 +10 了
     });
     console.log(numArray_1);//[6, 17, 18, NaN]
     console.log(new_numArray_1);// [17, 18]
    
     console.log("\n\n====2. 所有元素+10 后都判断=====\n\n");
    
     const numArray_2 = [6,7,8];
    
     const new_numArray_2 = numArray_2.filter((item,index,array)=>{
         array[index] += 10;  //从当前元素就改变,即:该变了数组中所有元素
         return array[index] > 10; 
         /**需要注意的是:
          * 这个只是过滤条件,装入新数组的是item,
          * 当前循环时item的值并没有改变(当前下标在数组中的元素值没有改变),
          * 所以装入新数组的是老数据
          */
     });
     console.log(numArray_2);//[16, 17, 18]
     console.log(new_numArray_2);//[6, 7, 8]
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第8张图片

2.4 例子3——在数组中搜索

  • 下例使用 filter() 根据搜索条件来过滤数组内容。
  • 代码如下:
     <script>
         const pets = ['dog-麦兜','dog-泡泡','cat-阿苔','dog-lucky','cat-点点'];
    
         const strs = ['I love you','love?','no','he is hate','love me?'];
    
         function filterIterms(array,query){
             return array.filter(arr => arr.includes(query.toLowerCase()));
         }
    
         let dogs = filterIterms(pets,'dog');
         let cats = filterIterms(pets,'cat');
         let loveStr = filterIterms(strs,'LOve');
    
         console.log(dogs);
         console.log(cats);
         console.log(loveStr);
     </script>
    
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第9张图片

3. map()

3.1 介绍

  • 简介:
    map() 方法创建一个新数组,这个新数组由原数组中的每个元素都调用一次提供的函数后的返回值组成。
  • 语法
    map(callbackFn)
    map(callbackFn, thisArg)
    
  • 参数、返回值
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第10张图片
  • 描述
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第11张图片

3.2 例子1——求数组中每个元素的2倍

  • 代码如下:

     const numArray = [1,3,5,7];
    
     const new_numArray = numArray.map(num => num*2 );
    
     console.log(numArray);
     console.log(new_numArray);
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第12张图片

3.3 例子2——使用 map 重新格式化数组中的对象

  • 代码如下:

     const kvArray = [
         { key: 1, value: 10 },
         { key: 2, value: 20 },
         { key: 3, value: 30 },
     ];
    
     const reformattedArray = kvArray.map(( {key, value} )=>{
         return ({[key]: value});
     });
    
     console.log(kvArray);
    
     console.log("\n\n======重新格式化数据之后=====\n\n");
     console.log(reformattedArray); // [{ 1: 10 }, { 2: 20 }, { 3: 30 }]
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第13张图片

  • 更多使用请参考官网:
    官网——Array.prototype.map().

4. reduce()

4.1 介绍

  • 使用说明
    • reduce() 方法对数组中的每个元素按序执行一个提供的 reducer 函数,每一次运行 reducer 会将先前元素的计算结果作为参数传入,最后将其结果汇总为单个返回值。
    • 第一次执行回调函数时,不存在“上一次的计算结果”。
    • 从第一个元素开始循环还是第二个元素开始循环,取决于有没有传初试值:
      • 如果传初试值:
        回调函数从数组索引为 0 的元素开始执行,汇总结果是:初试值 + 数组中的每个元素
      • 如果没有传初试值:
        数组索引为 0 的元素将被用作初始值,迭代器将从第二个元素开始执行。
  • 语法
    reduce(callbackFn)
    reduce(callbackFn, initialValue)
    
  • 参数 + 返回值
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第14张图片
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第15张图片
  • 描述
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第16张图片

4.2 例子1——数组元素求和

  • 代码如下:

    <script>
        
        const numArray = [1,2,3,4];
    
        /**
         * 没有初试值时:
         * 1. accumulator的值:在第一次调用时,如果没有指定 初始值 则为 数组中的第一个值;
         * 2. 并且 callbackFn 从数组中的第二个值作为 currentValue 开始执行。
         */
        const result_1 = numArray.reduce((accumulator, currentValue)=>{
            console.log(currentValue);
            return accumulator + currentValue;
        });
    
        console.log("结果:" + result_1);//没有初试值:1+2+3+4 = 10
    
    
        console.log("\n\n\n========给初试值的情况======\n\n\n");
    
        /**
         * 有初试值:
         * 1. accumulator的值:在第一次调用时,如果指定了 初始值 则为指定的初始值
         * 2. callbackFn 从数组中的第一个值作为 currentValue 开始执行
         */
        const result_2 = numArray.reduce((accumulator, currentValue)=>{
            console.log(currentValue);
            return accumulator + currentValue;
        },200); //指定初试值:200
    
        console.log("结果:" + result_2);//有初试值:200+1+2+3+4 = 210
    
    </script>
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第17张图片

4.3 例子2——求对象数组中某属性值的总和

  • 代码如下:
        <script>
    
            function Dog(dogName,dogAge){
                this.dogName = dogName,
                this.dogAge = dogAge
            }
    
            let dog_1 = new Dog('麦兜',3);
            let dog_2 = new Dog('泡泡',5);
            let dog_3 = new Dog('大牙',2);
    
            const dogs = [dog_1,dog_2,dog_3];
    
            // console.log(dogs);
            
            const sumAge = dogs.reduce((pre,cur)=>{
                return pre + cur.dogAge;
            },0);
    
            console.log(sumAge);
            
        </script>
    
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第18张图片

4.4 例子3——展平嵌套数组

  • 如下:

      //展平嵌套数组
      const array = [[1,2],[3,4],[5,6]];
    
      const new_array = array.reduce((accumulator, currentValue)=>{
          return [...accumulator,...currentValue];
      });
    
      console.log(new_array);
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第19张图片

4.5 例子4——统计对象中值的出现次数

  • 如下:

      //统计对象中值的出现次数
    
      const strs = ['you','love','I','love','beautiful','go'];
    
      const count_result = strs.reduce((countSum,currentStr)=>{
          if(currentStr === 'love'){
              return countSum + 1;
          }
          return countSum;
      },0);
    
      console.log("love 单词出现的次数:" + count_result);
    

    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第20张图片

4.6 例子5——数组去重

  • 如下:
     //去重
     const strs = ['you','love','go','love','beautiful','go'];
    
     let result = strs.reduce((countSum,currentStr)=>{
         if(countSum.includes(currentStr)){
             return countSum;
         }else{
             return [...countSum,currentStr];
         }
     },[]);
    
     console.log(strs);
     console.log(result);
    
    JavaScript 之 常用迭代方法forEach、filter()、map()、reduce()_第21张图片
    更多用法,请参考官网:
    官网——Array.prototype.reduce().

你可能感兴趣的:(VUE,+,JS,ES6,NodeJs等,javascript,开发语言,ecmascript)