Javascript的call和bind的区别

var a={

name:"aaa"

}

var b={

name:"bbb"

}

var box=document.getElementsByClassName("box")[0];

box.onclick=function(){

console.log(this.name)

}.call(a) //call会马上执行  因为匿名函数的调用者不再是box了,onclick是box的属性

box.onclick=function(){

console.log(this.name)

}.bind(b) //bind要点击才执行

//事实上,函数执行时,this会作为一个隐形的参数传入函数体中

//bind函数的作用是指把传入的this参数改为bind的参数

var obj={

x:81

}

var foo={

getX:function(){

return this.x

}

}

console.log(foo.getX.bind(obj)()) //bind要加()才执行

console.log(foo.getX.call(obj))

console.log(foo.getX.apply(obj))

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 各位观众老爷大家好,欢迎收看内裤总动员之程序猿的IT程序大讲堂,今天给大家分享一个小知识.就是call和apple...
    5034af144007阅读 5,694评论 2 4
  • 单例模式 适用场景:可能会在场景中使用到对象,但只有一个实例,加载时并不主动创建,需要时才创建 最常见的单例模式,...
    Obeing阅读 6,618评论 1 10
  • Javascript 中的 this,有时候让人迷惑,所以总结了一下关于this指向的问题。 在函数中 this ...
    lxt410725阅读 3,276评论 0 1
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,419评论 2 17
  • 参考链接 this 关键字 深入理解上下文this 慕课视频 基本含义 以上示例中实际都是执行的showName方...
    day_day_up阅读 4,464评论 2 3

友情链接更多精彩内容