web前端面试题附答案043 - 面试官让给数组添加一个方法,可以实现内部数字的累加

这道题是考数组的一个内置函数,当然,你不会也能做,题目已经说了,累加嘛

1、我就喜欢累加 

        既然是数组,那么就开始遍历,遍历之前定义一个变量为0,然后遍历的过程中实现累加。

<script>
   let num = 0;
   let arr = [1, 3, 5, 7, 9, 111];
   arr.forEach((item) => {
     num += item;
   })
   console.log(num); // 136
</script>

2、高阶函数 reduce

        但总有人觉得遍历做这道题太傻了,太初级了,而且也是最近几年新出了内置函数 reduce,

reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

注意: reduce() 对于空数组是不会执行回调函数的

<div id="demo"></div>
<script>
    var arr = [1, 3, 5, 7, 9, 111];

    function getSum(total, num) {
        return total + num;
    }
    function myFunction() {
        document.getElementById("demo").innerHTML = arr.reduce(getSum);
    }

    myFunction();
</script>

3、自己实现一个

        要求自己实现以后呢,例如添加一个mySum()的方法,可以通过arr.mySum(),就可以实现累加,这个怎么搞呢?

        首先给数组添加一个方法,一定会用到prototype,在数组的原型链上添加一个方法,而内部的this呢,指向了数组本身,看上去是不是挺像内部走了一下valueOf函数

<script>
  let arr = [1, 3, 5, 7, 9, 111];
  Array.prototype.mySum = function() {
    console.log(this); // [1, 3, 5, 7, 9, 111]
  }
  arr.mySum();
</script>

        这个时候就可以在内部实现一些自己的逻辑了,而且不止于累加,还可以对内部一些元素做逻辑判断。

        更大的好处在于当项目中如果有一些特殊的需求,而且目前内置函数不能满足,就可以考虑自己封装了。

        比如有一段时间,在异步请求到数据的时候,前端都是拼接字符串,不像现在有模板框架,那个时候我把一段段的dom字符串push到一个数组里,然后最后在转为一个大的字符串,innerHTML到预备好的div中。但当服务端返回某个字段有异常的时候,我就需要在业务逻辑代码里不断判断

<script>
    $.ajax({
        url: xxx,
        data: {},
        ......
        success: function(data) {
            var arr = [];
            arr.push('<div>');
            if (data['num']) {
                arr.push(data['num']);
            } else {
                arr.push('--');
            }
            arr.push('</div>');
        }
    })
    
</script>

        可以说这种判断到处都是,弄得开发人员痛苦的不行,而且也使业务代码变得更乱套。但如果自己封装一个方法,就可以少很多麻烦事。比如先封装一个myPush方法给数组,使其正常的情况下就push正常内容,异常情况下push兜底内容

<script>
    Array.prototype.myPush = function(data) {
        if (data) {
            this.push(data);
        } else {
            this.push('--');
        }
    }
</script>

        如此一来,通过封装新的方法,大家是不是就可以使用arr.myPush(xx)来添加内容了,就可以减少考虑的时间,抽更多的时间来做业务开发了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

经海路大白狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值