当前位置: 首页 > 编程笔记 >

javascript中利用柯里化函数实现bind方法【推荐】

滑景胜
2023-03-14
本文向大家介绍javascript中利用柯里化函数实现bind方法【推荐】,包括了javascript中利用柯里化函数实现bind方法【推荐】的使用技巧和注意事项,需要的朋友参考一下

• 柯理化函数思想:一个js预先处理的思想;利用函数执行可以形成一个不销毁的作用域的原理,把需要预先处理的内容都储存在这个不销毁的作用域中,并且返回一个小函数,以后我们执行的都是小函数,在小函数中把之前预先存储的值进行相关的操作处理即可;

• 柯里化函数主要起到预处理的作用;

• bind方法的作用:把传递进来的callback回调方法中的this预先处理为上下文context;

/**
* bind方法实现原理1
* @param callback [Functhtml" target="_blank">ion] 回调函数
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
function bind(callback,context) {
  var outerArg = Array.prototype.slice.call(arguments,2);// 表示取当前作用域中传的参数中除了fn,context以外后面的参数;
  return function (){
    var innerArg = Array.prototype.slice.call(arguments,0);//表示取当前作用域中所有的arguments参数;
    callback.apply(context,outerArg.concat(innerArg));
  }
}
/**
* 模仿在原型链上的bind实现原理(柯理化函数思想)
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
Function.prototype.mybind = function mybind (context) {
  var _this = this;
  var outArg = Array.prototype.slice.call(arguments,1);
  // 兼容情况下
  if('bind' in Function.prototype) {
    return this.bind.apply(this,[context].concat(outArg));
  }
  // 不兼容情况下
  return function () {
    var inArg = Array.prototype.slice.call(arguments,0);
    inArg.length === 0?inArg[inArg.length]=window.event:null;
    var arg = outArg.concat(inArg);
    _this.apply(context,arg);
  }
}

以上这篇javascript中利用柯里化函数实现bind方法【推荐】就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍JavaScript函数柯里化详解,包括了JavaScript函数柯里化详解的使用技巧和注意事项,需要的朋友参考一下 什么是柯里化 柯里化是这样的一个转换过程,把接受多个参数的函数变换成接受一个单一参数(译注:最初函数的第一个参数)的函数,如果其他的参数是必要的,返回接受余下的参数且返回结果的新函数。 柯理化函数思想:一个js预先处理的思想;利用函数执行可以形成一个不销毁的作用域的原

  • 一、函数 1.1 函数与方法 Scala 中函数与方法的区别非常小,如果函数作为某个对象的成员,这样的函数被称为方法,否则就是一个正常的函数。 // 定义方法 def multi1(x:Int) = {x * x} // 定义函数 val multi2 = (x: Int) => {x * x} println(multi1(3)) //输出 9 println(multi2(3)) //输出

  • Scala 函数 柯里化(Currying)指的是将原来接受两个参数的函数变成新的接受一个参数的函数的过程。新的函数返回一个以原有第二个参数为参数的函数。 实例 首先我们定义一个函数: def add(x:Int,y:Int)=x+y 那么我们应用的时候,应该是这样用:add(1,2) 现在我们把这个函数变一下形: def add(x:Int)(y:Int) = x + y 那么我们应用的

  • 本文向大家介绍深入剖析JavaScript中的函数currying柯里化,包括了深入剖析JavaScript中的函数currying柯里化的使用技巧和注意事项,需要的朋友参考一下 curry化来源与数学家 Haskell Curry的名字 (编程语言 Haskell也是以他的名字命名)。   柯里化通常也称部分求值,其含义是给函数分步传递参数,每次传递参数后部分应用参数,并返回一个更具体的函数接受

  • 函数绑定 在JavaScript的高级技巧中有一种技术叫函数绑定。 函数绑定要创建一个函数,可以在特定的this环境中以指定参数调用另一个函数。它常常与函数回调与事件处理程序一起使用,以便将函数作为变量传递时保留代码的 执行环境。 这里创建的函数就是通过绑定之后返回的函数,调用的另一个函数就是原始函数(被绑定的函数)。 bind()方法实现绑定 这个方法的主要作用就是将 函数绑定到某个对象上。当

  • 转换一个异步函数,以返回一个 promise 。 使用柯里化返回一个函数,这个函数返回一个调用原始函数的 Promise 。 使用 ...rest 运算符传入所有参数。 在 Node 8+ 中,你可以使用 util.promisify const promisify = func => (...args) => new Promise((resolve, reject) => func