javascriptthis详细介绍-创新互联

this的值是在运行时确定的

  JS中的this究竟代表什么,这是在程序运行时根据上下文环境确定,可以分为以下几种情况。

  1. 全局作用域中的this

  在全局作用域中,this指向window对象。

  ?

  1

  2

  3

  4

  5

  6

  console.log(this);//指向window对象

  this.x = 5//在全局作用域内创建一个x

  //与this.x = 5的等价情况:

  //var x = 5;

  //x = 5;

  在全局作用域中执行var x=5,其实是为window对象创建一个属性x,并令其等于5。

  若定义变量时不加var,JS会认为该变量为全局变量,会将其当作window对象的属性。

  2. 函数中的this

  JS中函数有两种,直接调用的函数称为普通函数,通过new创建对象的函数称为构造函数。

  2.1 构造函数中的this

  构造函数的this指向它所创建的对象,如:

  ?

  1

  2

  3

  4

  function Person(name){

  this.name = name;//this指向该函数创建的对象person

  }

  var person = new Person("chaimm");

  2.2 普通函数中的this

  普通函数的this指向window对象。

  若上述例子,直接执行Perosn函数,则其中this代表window对象,因此该函数执行后会创建一个全局的name。

  ?

  1

  2

  3

  4

  function Person(name){

  this.name = name;//this指向window

  }

  Person("chai");//当作普通函数执行,this指向window对象

  3. 对象中的this

  对象中的this指向当前对象,如:

  ?

  1

  2

  3

  4

  5

  6

  var person = {

  name : "chaimm",

  getName : function(){

   return  this.name;

  }

  }

  上述代码中this指向函数getName所属的对象。

  但是,如果一个对象的函数中又嵌套了一个函数,这个函数的this指向的却是window,而并不是其外层的对象。

  ?

  1

  2

  3

  4

  5

  6

  7

  8

  var person = {

  name : "chaimm",

  setName : function(name){

  (function(name){

  this.name = name; //此时this并不代表person对象,而是代表window对象

  })(name);

  }

  }

  上述示例中,person对象中有一个getName函数,而getName函数内部又有一个函数,这个函数内部的this指向window对象,而非person对象,这是JS的一个bug!一般作如下处理,规避这个bug:

  ?

  1

  2

  3

  4

  5

  6

  7

  8

  9

  var person = {

  name : "chaimm",

  setName : function(name){

  var thar = this;//将this赋给that

  (function(name){

  that.name = name;//此时that指向person对象

  })(name);

  }

  }

  我们在person对象的第一层函数中,将this赋给局部变量that,然后在第二层函数中使用that,此时that指向person对象,可对person的属性进行操作。

  注意:若将一个对象中的函数赋给一个变量后,再通过该变量调用这个函数,此时该函数中的this指向window,而非该对象,如下所示:

  ?

  1

  2

  3

  4

  5

  6

  7

  8

  9

  10

  11

  var person = {

  name : "chaimm",

  getName : function(){

  return this.name;

  }

  }

  //将getName函数赋给一个新的变量

  var newGetName = person.getName;

  //通过新的变量调用这个函数,这个函数中的this将指向window

  newGetName();//若全局作用域中没有name,则将返回undefined

  4. 用 call 和apply函数给this开挂

  这两个函数都能手动指定被调用函数内部的this指向哪个对象。

  ?

  1

  2

  3

  4

  5

  6

  7

  8

  9

  10

  11

  12

  13

  14

  //定义一个构造函数

  var Person = function(name){

  this.name = "";

  this.setName = function(name){

  this.name = name;

  }

  }

  //创建两个对象

  var personA = new Person("A");

  var personB = new Person("B");

  //使用personA的setName函数去修改personB的name属性

  personA.setName.apply(personB,["C"];

  apply用法

  对象A.函数名。apply(对象B, 参数列表);

  当对象B作为apply的第一个参数传给apply时,对象A的函数中this就指向了对象B,此时对象A的该函数对this的操作将会作用在对象B上,由此实现了用对象A去调用对象B的函数。

创新互联一直通过网站建设和网站营销帮助企业获得更多客户资源。 以"深度挖掘,量身打造,注重实效"的一站式服务,以做网站、网站制作、移动互联产品、营销型网站建设服务为核心业务。十载网站制作的经验,使用新网站建设技术,全新开发出的标准网站,不但价格便宜而且实用、灵活,特别适合中小公司网站制作。网站管理系统简单易用,维护方便,您可以完全操作网站资料,是中小公司快速网站建设的选择。

/tupian/20230522/


网站栏目:javascriptthis详细介绍-创新互联
标题链接:http://scyanting.com/article/gcspo.html