javascript - 外部函数接收三个参数,里面的函数只需要一个参数或者需要四个参数的时候,里面的函数的参数怎么被赋值的?

查看:150
本文介绍了javascript - 外部函数接收三个参数,里面的函数只需要一个参数或者需要四个参数的时候,里面的函数的参数怎么被赋值的?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

  var optimizeCb = function(func, context, argCount) {
    // 如果没有指定 this 指向,则返回原函数
    if (context === void 0) return func;

    switch (argCount == null ? 3 : argCount) {
      case 1: return function(value) {                        //这里的value从哪里来的
        return func.call(context, value);       
      };
      case 2: return function(value, other) {                 //这里的other从哪里来的
        return func.call(context, value, other);  
      };

      // 如果有指定 this,但没有传入 argCount 参数
      // 则执行以下 case
      // _.each、_.map
      case 3: return function(value, index, collection) {     //还有这里的index,collection
        return func.call(context, value, index, collection);
      };

      // _.reduce、_.reduceRight
      case 4: return function(accumulator, value, index, collection) {    //这里的accumulator
        return func.call(context, accumulator, value, index, collection);
      };
    }
    return function() {
      return func.apply(context, arguments);
    };
  };

解决方案

这不就是闭包吗,当你调用外层函数的时候,返回了一个新的函数,然后你再给返回的函数传值

例如:

 function fn1(a){
   return function(b){
     console.log(a+b)
   }
 }
 
 var fn2 = fn1('hello') //这时候的值是返回的函数
 fn2('world') //这时候执行里面的函数 得到 helloworld

这篇关于javascript - 外部函数接收三个参数,里面的函数只需要一个参数或者需要四个参数的时候,里面的函数的参数怎么被赋值的?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆