首页
学习
活动
专区
圈层
工具
发布

JavaScript 中至关重要的 Bind

面试官:请你讲讲 js 中 Bind 本文翻译自: http://javascriptissexy.com/javascript-apply-call-and-bind-methods-are-essential-for-javascript-professionals...JavaScript 中至关重要的 Bind 我们用 Bind() 来实现在指明函 数内部 this 指向的情况下去调用该函数, 换句话说, bind() 允许我们非常简单的在函数或者方法被调用时绑定...在 JavaScript 中这种问题比较常见, JavaScript 框架中例如 Backbone.js, jQuery 都自动为我们做好了绑定的工作, 所以在使用时 this 总是可以绑定到我们所期望的那个对象上...(user); Bind 方法允许我们实现函数借用 在 JavaScript 中, 我们可以传递函数, 返回函数, 借用他们等等, 而 bind() 方法使函数借用变得极其简单...."; } } 接着我们使用 bind() 方法柯里化 greet() 方法. bind() 接收的第一个参数指定了 this 的值: // 在 greet 函数中我们可以传递 null, 因为函数中并未使用到

74430
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    理解JavaScript中的This,Bind,Call和Apply

    this关键词在JavaScript中是个很重要的概念,也是一个对初学者和学习其他语言的人来说晦涩难懂。在JavaScript中,this是一个对象的引用。...在Understanding Variables, Scope, and Hoisting in JavaScript中,你学习到函数中的变量有自己的上下文。...由于游戏逻辑需要用户输入,比如按键或点击事件,你可能想要bind事件去获取游戏逻辑类中的this的值。...如果在这里,你并没有使用箭头函数,this将等同于event.currentTarget,如没有显示绑定this,你将不能获取类中的值。这种策略通常使用在像React这样框架的类方法上。...总结 在这篇文章中,你学到了关于JavaScript的this,和基于隐式运行时绑定的可能具有的不同值,以及通过bind,call和apply的显示绑定。

    64740

    JavaScript中apply、call、bind的区别与用法

    apply()、call()和bind()方法都是Function.prototype对象中的方法,而所有的函数都是Function的实例。三者都可以改变this的指向,将函数绑定到上下文中。 1....语法: fun.bind(thisArg, 队列or数组)() 2. 用法 这三个方法的用法非常相似,将函数绑定到上下文中,即用来改变函数中this的指向。 2.1 普通写法 ?...不同之处在于,在给调用函数传递参数时,apply()是数组,call()参数是逐个列出的。 2.3 bind()的用法 ? bind方法传递给调用函数的参数可以逐个列出,也可以写在数组中。...总结bind()的用法:该方法创建一个新函数,称为绑定函数,绑定函数会以创建它时传入bind()的第一个参数作为this,传入bind()的第二个以及以后的参数加上绑定函数运行时本身的参数按照顺序作为原函数的参数来调用原函数...//developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Function/bind jianshu.com/

    1.4K20

    【译】理解JavaScript中的This,Bind,Call和Apply

    this关键词在JavaScript中是个很重要的概念,也是一个对初学者和学习其他语言的人来说晦涩难懂。在JavaScript中,this是一个对象的引用。...在Understanding Variables, Scope, and Hoisting in JavaScript中,你学习到函数中的变量有自己的上下文。...由于游戏逻辑需要用户输入,比如按键或点击事件,你可能想要bind事件去获取游戏逻辑类中的this的值。...如果在这里,你并没有使用箭头函数,this将等同于event.currentTarget,如没有显示绑定this,你将不能获取类中的值。这种策略通常使用在像React这样框架的类方法上。...总结 在这篇文章中,你学到了关于JavaScript的this,和基于隐式运行时绑定的可能具有的不同值,以及通过bind,call和apply的显示绑定。

    1K20

    JavaScript中call,apply,bind方法的使用及原理

    在JavaScript里,call(),apply(),bind()都是Function内置的三个方法, 它们的作用都是显示的绑定this的指向,三个方法的第一个参数都是this指向的对象,也就是函数在运行时执行的上下文...当我们定义一个新的对象,需要使用其他对象的方法的时候,我们不需要重新开发重复的方法逻辑,借助apply,apply,bind三个方法可以实现对这些的方法的调用。...bind()方法创建一个新的函数,在bind()被调用时,这个新函数的this被bind的第一个参数指定,其余的参数将作为新函数的参数供调用时使用,第一个thisArg在setTimeout中创建一个函数时传递的原始值都会转化成...cacheFun.getCacheName(); // Name is cache let cacheName = cacheFun.getCacheName; cacheName(); // Name: global 在创建绑定函数的实例中...window对象,所以this.name获取的是global 我们需要借助bind方法,在函数调用的时候,绑定this的执行到cacheFun对象上: let cacheNameByBind = cacheName.bind

    1.4K20

    关于JavaScript中apply、call、bind的详细使用讲解

    在JavaScript中我们对函数的执行通常是直接用函数的名称加个括号就可以进行调用了,但是这样调用有一个缺点,就是函数中的this指向是默认绑定的,有时候this的指向不太符合我们的预期。...至于JavaScript中this的指向可以看我这篇文章《在JavaScript中,this的指向详细讲解》那我们想要把函数的this指向变成我们预期想的那样有什么方法吗?...这时候JavaScript中的函数apply、call、bind调用就起到作用了applyapply接受两个参数,第一个参数是this的指向,第二个参数是函数接受的参数,以==数组==的形式传入,==且当第一个参数为...==bind 返回的是一个新的函数,你必须调用它才会被执行。...])()//bind调用后的结果总结call 、bind 、 apply 这三个函数的第一个参数都是 this 的指向对象,第二个参数差别就来了。

    32110

    JavaScript 中 `apply`、`call` 和 `bind` 的具体理解与区别

    JavaScript 中 apply、call 和 bind 的具体理解与区别apply、call 和 bind 是 JavaScript 中函数方法,用于改变函数的 this 指向,尤其在函数调用时动态绑定上下文对象...3.3 bind 的应用场景示例:事件处理时绑定上下文bind 通常用于创建函数的副本,并绑定特定的 this,特别是在事件处理时。...(`Button says: ${this.text}`); }};// 在 DOM 事件中绑定上下文const boundClickHandler = button.handleClick.bind...call参数数量固定,或明确传递的场景,适合动态切换上下文。bind创建一个新函数用于延迟调用,并绑定 this 和部分参数(如事件监听器)。...合理使用 apply、call 和 bind 可以提升代码的灵活性与可复用性,是 JavaScript 高级编程的重要技能。

    28810

    说下js中的bind

    bind的受体是对象,返回的是个新的函数。 我们知道this总是指向调用他的对象。但是有时候我们希望‘固化’这个this。 也就是无论怎么调用这个返回的函数都有同样的this值。...这就是bind的作用。 语法 fun.bind(thisArg[, arg1[, arg2[, ...]]]) 参数 thisArg 当绑定函数被调用时,该参数会作为原函数运行时的 this 指向。...this将永久地被绑定到了bind的第一个参数,无论这个函数是如何被调用的。 arg1, arg2, ... 当绑定函数被调用时,这些参数将置于实参之前传递给被绑定的方法。...//developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Function/bind https://www.smashingmagazine.com.../2014/01/understanding-javascript-function-prototype-bind/#what-problem-are-we-actually-looking-to-solve

    2.5K10

    【优雅代码】深入浅出 妙用Javascript中apply、call、bind

    apply、call  在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向。...JavaScript 中,某个函数的参数数量是不固定的,因此要说适用条件的话,当你的参数是明确知道数量时用 call 。 而不确定的时候用 apply,然后把参数 push 进数组传递进去。...中存在一种名为伪数组的对象结构。...因此,这里我们传入想要的上下文 this(其实就是 foo ),到 bind() 函数中。然后,当回调函数被执行的时候, this 便指向 foo 对象。...答案是,两次都仍将输出 3 ,而非期待中的 4 和 5 。原因是,在Javascript中,多次 bind() 是无效的。

    53920

    javascript中bind绑定接收者与函数柯里化

    ,this对象指向的并不是obj,而是forEach的对象,forEach的对象是全局对象golobal; 那想实现意图怎么办呢?...更好的办法是: arr.forEach(obj.add.bind(obj)); bind创建了一个新函数,这个函数跟obj.add一样,唯一不同的是,新函数把this绑定了obj 也就是说把add方法绑定给了接收者...你可以直接在bind方法里直接传递这个参数: arr.forEach(obj.add.bind(obj, "mytitle")); 最终的代码是: let obj = { add(title,...console.log(param); console.log(index) } } let arr = ['a', 'b', 'c']; arr.forEach(obj.add.bind...(obj, "mytitle")); 输出结果是: mytitle a 0 mytitle b 1 mytitle c 2 将函数与其参数的一个子集绑定的技术称为函数的柯里化; 比起显式的封装函数,这样做更简洁

    53020
    领券