最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 数组拓展方法(一):forEach、filter、map

    正文概述 掘金(我会接网线)   2020-12-29   555

    数组拓展方法是从ES5中才使用的

    一. JSON与数组的联系

    知识回顾:很多大的项目JSON数据存在HTML中,减少了对服务器的请求
    同时以数组的形式存储多项JSON数据:[{……},{……},{……}],这样的方式称之为 JSON对象集合 也叫 JSON数据集合

    这样的话就形成了一套数据结构 ( 对象中各项打上引号、 []存储多项对象 ),这种数据结构称之为JSON
    JSON数据就是对象,JSON数据集合就是数组

    数组里面每一个值 称之为 数组元素 element

    二. forEach(): 遍历

    1. forEach()

    它是遍历数组的方法: forEach() 方法用于调用数组的每个元素,并将元素传递给回调函数。

     data = [1, 2, 3];
           data.forEach(myFunction);
    
           function myFunction(item) {
               var sum = 0;
               for (var i = 0; i < data.length; i++) {
                   sum = sum + data[i];
               }
               console.log(sum);
           }
    

    因为data中有三个元素,所以遍历function三次,输出 6 三次

    forEach()是数组的原型上面的方法(Array.prototype)
    所以说只能数组用这个方法,对象等不能用

    forEach()每遍历出一个元素就会执行一次function-->需要提供三个参数:

    data.forEach(function(elem, index, ayyay){ /数组元素, 索引, 正在遍历的数组
     console.log(this);
    });
    

    elem:当前数组的元素
    index: 当前元素的下标
    array:正在遍历的数组

    因为数组里面每一个值 称之为 数组元素 element
    所以在forEach()中常把 data[i]写成 elem, 把 i 写成 index
    同时这里面的this指向window
    同时forEach()的 括号里面有两个参数, 第二个参数更改函数内部的this指向

    因为 var data = [ ' 1 ' , ' 2 ' ]; ,有两个元素, 所以以下结果输出两次:

      <script>
            var data = ['1', '2'];
            data.forEach(function (elem, index, ayyay) {
                console.log(this);
            },{name: 'test'});      /返回:{name: "test"}
            
            
              var data = ['1', '2'];
            data.forEach(function (elem, index, ayyay) {
                console.log(this);
            },1);                  /返回 Number {1}
           
            
              var data = ['1', '2'];
            data.forEach(function (elem, index, ayyay) {
                console.log(this);
            }, false);                    /返回 Boolean {false}
       
       
         var data = ['1', '2'];
            data.forEach(function (elem, index, ayyay) {
                console.log(this);
            },undefined);      /Window {parent: Window, opener: null, top: Window, length: 0, frames: Window, …}
        </script>
    

    因为this 一定会指向一个对象, 所以填1、false等会强制给它转换成对象形式(包装类知识), 所以第二个参数填null、undefined 时不成功

    2. forEach()方法的重写

    重写: 详细写该方法的原理
    因为data内只有一个{} ,所以结果只输出一次

           var data = [1, 2, 3];
                var fn = function (elem, index, array) {
    
                    console.log(this);  //指向data,因为data调用此方法
                }
    
                Array.prototype.myFroEach = function (fn) {
                    var arr = this,  //因为是数组去调用自定义的方法,所以this指向该数组, 在方法中声明一个变量arr 去保存this
                        len = arr.length,
                        args2 = arguments[1] || window; //如果传入了第二个参数 就将其保存到args2, 如果没传,args就保存window
    
    
                    for (var i = 0; i < len; i++) {
                        fn.apply([arr[i], i, arr], args2)  //每循环一次 都要遍历这个函数fn,  
                    //使用apply 改变该函数的指向, 原本fn指向window, apply之后指向参数args2, 即下面的Sum
                    }
                }
    
                function Sum(item) {
                    var sum = 0;
                    for (var i = 0; i < data.length; i++) {
                        sum = sum + data[i];
                    }
                    console.log(sum);
                }
    
                data.forEach(fn, Sum)
    

    输出Sum函数整体三次,但是Sum并不会执行
    需要打上()才会执行,即 data.forEach(fn, Sum());输出三个6

    三. filter(): 筛选、过滤

    与forEach() 最大的不同是 它会返回一个新的数组,即不会改变原数组:

       <script>
            var data = [{ 'name': '0', 'age': '18' }];
    
            var newArr = data.filter(function (elem, index, array) {
                return elem.name === '0';  //正确就返回data ,错误就返回空
    
            })
            console.log(newArr);
        </script>
    

    该方法通过返回的值是 true还是false 来判断哪些数据需要放到新数组中去

    filter()方法的重写

    <script>
            var data = [{ 'name': '0', 'age': '18' }];
    
            var fn = function (elem, index, array) {
                return elem.name === '0';
                  console.log(this);
            }
    
            Array.prototype.myFilter = function (fn) {
                var arr = this,
                    len = arr.length,
                    args2 = arguments[1] || window,
                    newArr = [],
    
                for (var i = 0; i < len; i++) {
                    fn.apply(args2, [arr[i], i, arr]) ? newArr.push(arr[i]) : " "; 
                    //true就返回数组,false返回空
                }
    
            }
    
            var newARR = data.myFilter(fn, [{ 'name': '0', 'age': '18' }]);
    
    
        </script>
    

    四. map: 映射

    map() 方法返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。 并不会改变原数组的值

      <script>
            var data = [{ 'name': '0', 'age': '18' }];
            var newArr = data.map(function (elem, index, arr) {
                elem.name = this.name + elem.name;
                // this.name 就是第二个形参的值, this指向第二个形参
                return elem;
            }, { 'name': '[JS前端]' })
            console.log(newArr);     
        </script>
    

    上式输出 {name: "[JS前端]0", age: "18"}
    可以得出结论: map的作用就是将参数的值放入到数据中: data.map(fn, args2)

    2. map() 方法 重写

            var data = [{ 'name': '0', 'age': '18' }];
            Array.prototype.myMap = function (fn) {
                var arr = this,
                    len = arr.length,
                    arg2 = arguments[1] || window,
                    nArr = [],
                    item;
    
                for (var i = 0; i < len; i++) {
                    item = arr[i];
           nArr.push(fn.apply(arg2, [item, i, arr]));  //唯一的不同就是for循环,for循环决定该方法的特性
                }
                return nArr;
            }
    
            var fn = function (elem, index, Array) {
                elem.name = this.name + elem.name;
                return elem;
            }
            var newArr = data.myMap(fn, { name: '[JS前端]' });
            console.log(newArr);
    
    

    所以map可以修改数据,又能添加数据

    总结

    这些重写方法 唯一的不同就是for循环, for循环决定该方法的特性


    起源地下载网 » 数组拓展方法(一):forEach、filter、map

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元