时间:2021-05-26
Javascript应该是现在最流行的跨平台语言之一,一直在玩前端的一些有意思的东西,发现竟然没有掌握好这门语言。有点舍本逐末,于是想趁着现在这有空的时候好好补充一点遗漏的东西。
this的隐性绑定
一开始这是我很迷惑的东西,刚开始看到的时候,不理解。而后,在相似的情况下,又能用类似的方法解决同样的问题。便试着理清这其中的知识,方便于查找。
这是一个Javascript语言上设计的错误,但是似乎这个错误是不可避免的,函数是对象,数组是对象等等。引用《Javascript: The Good Parts》中的例子
复制代码 代码如下:
function add (a,b) {return a+b}
var sum = add (3,4);
console.log(sum); //sum = 7
此时sum的结果是7。
复制代码 代码如下:
> typeof add
> 'number'
在这里可以看到,add的类型是数值。
以此模式调用函数时,this被绑定到全局变量。
也就是在现在的环境下,我们可以这样调用this
复制代码 代码如下:
this.add(3,4)
这就是this的隐性绑定,而this会以不同的方式被绑定。
复制代码 代码如下:
var hello = function (){
return "Hello, " + this.name;
};
name = 'this';
console.log(hello());
这时我们就会得到Hello,this。而当
复制代码 代码如下:
var hello = function (){
return "Hello, " + this.name;
};
var user = {
hello : hello,
name : 'phodal',
};
console.log(user.hello());
这时user中的hello便指向了hello函数,而这在我们的理解中,这怎么可能,所以是个Bug。
如果我们在这个方法中定义一个变量并给它赋值this,那么内部函数就可以通过那个变量访问到this。
var that = this
于是当情况稍微复杂一点的时候我们就需要用到:
复制代码 代码如下:
vat that = this;
tips:
1.this变量的作用域总是由其最近的封闭函数所确定。
2.使用一个局部变量(如me,self,that)让this绑定对于内部是可用的。
一个简单的例子:
复制代码 代码如下:
var M = function(){
this.name = "M";
};
var MM = function(){
z = new M();
this.name = "MM";
z.printName = function(){
console.log(this.name);
};
return z.printName();
};
var mm = new MM;
这时的this指向的是M函数,而由MM自身。如果我们将M中的this去掉,那么返回的就是一个undefined。 于是我们就创建一个当前this作用域的别名,如that或者self等等:
复制代码 代码如下:
var MM = function(){
z = new M();
this.name = "MM";
var self = this;
z.printName = function(){
console.log(self.name);
};
return z.printName();
};
这样就能返回一个MM了。除此之外,在ES5中可以用回调函数的bind方法。
复制代码 代码如下:
var MM = function(){
z = new M();
this.name = "MM";
z.printName = function(){
console.log(this.name);
}.bind(this);
return z.printName();
};
bind可以将方法绑定到接收者。
其他
又一个hello,world
在一次偶然的机会中遇到print('Hello')('World'),然后输出了'Hello, World'。
所谓的高阶函数,看上去似乎很有用,有兴趣可以看看下一篇。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
网站建设都想要选择一些热门的关键字,如果是一些小型网站在面对竞争力这么大的情况下,建议选择长尾关键字进行优化。热门的关键字一般都被大型的网站抢了,而且在资金以及
本文实例讲述了JavaScript中的this妙用。分享给大家供大家参考,具体如下:JavaScript关键字this始JS脚本能够根据使用这个关键字的上下文将
关键字的选择对营销网站来说是非常重要的,今天我们就来讨论一下营销网页制作的过程中,选择关键字的一些小妙招,希望可以帮助到有需要的站长朋友。 靠前、先要对关
前言在Java中,有一个常被忽略但非常重要的关键字Synchronized今天,我将详细讲解Java关键字Synchronized的所有知识,希望你们会喜欢目录
和其他高级语言一样javascript中也有new关键字,我们以前认知的new是用来创建一个类的实例对象,但在js中万物皆是对象,为何还要new关键字呢,其实j