使用 this 关键字定义方法和属性

1、方法和属性的定义

属性是类中声明的变量,与其他地方变量的声明基本相同,只是属性必须 this 关键字,并且这里没有var 关键字。

this.age;

在使用时,先是 this 关键字,之后的点语法连接的是方法名,就像是声明一个匿名函数,只不过属于 this 关键字。

参数 arg_1,arg_n等都是该方法使用的参数,参数之间使用逗号隔开,这也被称为参数列表。在参数后的花括号{},即为整个方法的内容。

方法如有返回值,使用 return 返回。

2、属性的初始化

当为类定义一个属性时,可以为属性赋值,称为属性的初始化。属性在定义时也可以没有初始值。

3、在类体内使用 this 关键字

在类内,如果要访问该类定义的方法或属性,必须使用 this 关键字,它表示类的实例自身,使用它可以引用当前代码的类的特定实例。

this 的行为与引用当前类的实例的变量类似。

4、易犯的错误

在方法内嵌入的函数形成一个新的运行环境,在该内嵌函数内使用 this 并不会指向对象的实例,而是指向全局对象 window。

function Foo(){}

Foo.prototype.method = function(){

 function test(){

  alert(this);

  // this 在这个对象里是全局函数

 }

 test();

}

var foo = new Foo();

foo.method();

要在嵌入的函数内使用 this,那么最好的是用一个中间变量,比如:

function Foo(){}

Foo.prototype.method = function(){

var that = this;

function test(){

  alert(that === foo );

  //that 在这个函数里是 foo对象

}

test();

}

var foo = new Foo();

foo.method();

 对于静态方法,存在相同的问题,使用相同的办法解决。

 

5、闭包方法(绑定方法)内的 this 关键字

 如果在闭包方法中使用 this 关键字要非常小心。闭包方法并不能确保 this 关键字总是引用在其中定义了方法的对象或类。

 

6、另外一个 使用 this 易犯的错误。

this 指向它执行的环境,如果构造方法不是使用 new 运算符创建实例,而是直接像调用函数那样调用,那么this关键字就不会代表该类的实例。

原文地址:https://www.cnblogs.com/chengmingxiaowu/p/7686456.html