这篇文章主要介绍了Javascript中的this,bind和that使用实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
Javascript中必须通过this来访问类成员,可是this的特点就是函数绑在哪个对象上,它就指向那个对象。这个可能困扰过很多的程序员,特别是从C#,Java等语言过来的程序员。
function Foo(){ this.message = 'This is message from Foo'; } Foo.prototype.printMessage = function(){ console.log(this.message); } function Foo2(){ this.message = 'This is message from Foo2'; } var foo = new Foo(); foo.printMessage(); var foo2 = new Foo2(); foo2.printMessage = foo.printMessage; foo2.printMessage();
输出为:
This is message from Foo
This is message from Foo2
主要原因就是this改变了,因此Javascript中this的用法,和C++\C#中的大为不同。如果需要传统方式使用this的函数,可以使用Function.prototype.bind(),指定函数的this值:
function Foo(){ this.message = 'This is message from Foo'; this.printMessage = (function(){ console.log(this.message); }).bind(this); } function Foo2(){ this.message = 'This is message from Foo2'; } var foo = new Foo(); foo.printMessage(); var foo2 = new Foo2(); foo2.printMessage = foo.printMessage; foo2.printMessage();
输出为:
This is message from Foo
This is message from Foo
另外使用call和apply也可以改变函数调用时的this值。
bind函数的主要问题是IE9以后才开始提供。并且一旦开始习惯了Javascript的this用法,这种bind反而会不习惯。在实践中,更多用到的还是保存this:
function Foo(){ var that = this; this.message = 'This is message from Foo'; this.printMessage = function(){ console.log(that.message); }; } function Foo2(){ this.message = 'This is message from Foo2'; } var foo = new Foo(); foo.printMessage(); var foo2 = new Foo2(); foo2.printMessage = foo.printMessage; foo2.printMessage();
输出同上。
注意我们是通过that来访问的message(除了that,context和self也是常用的名称)。Javascript一个还算欣慰的地方就是他的闭包上下文始终是在函数定义的地方,因此不管函数被挂上哪个对象上,捕获到的that始终是这个。当然这个地方不算闭包,有闭无包,但原理是相同的。这也是实践中用的最多的方法,推荐使用。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。