javascript this详细介绍


Posted in Javascript onSeptember 19, 2016

this的值是在运行时确定的

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

1. 全局作用域中的this

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

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指向它所创建的对象,如:

function Person(name){
  this.name = name;//this指向该函数创建的对象person
}
var person = new Person("chaimm");

2.2 普通函数中的this

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

function Person(name){
  this.name = name;//this指向window
}
Person("chai");//当作普通函数执行,this指向window对象

3. 对象中的this

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

var person = {
  name : "chaimm",
  getName : function(){
    return this.name;
  }
}

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

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

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:

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,而非该对象,如下所示:

var person = {
  name : "chaimm",
  getName : function(){
    return this.name;
  }
}

//将getName函数赋给一个新的变量
var newGetName = person.getName;
//通过新的变量调用这个函数,这个函数中的this将指向window
newGetName();//若全局作用域中没有name,则将返回undefined

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

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

//定义一个构造函数
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的函数。

以上就是对javascript this的资料整理,后续继续补充相关资料,谢谢大家对本站的支持!

Javascript 相关文章推荐
JavaScript QueryString解析类代码
Jan 17 Javascript
在JavaScript中获取请求的URL参数[正则]
Dec 25 Javascript
jquery form 加载数据示例
Apr 21 Javascript
微信JS-SDK坐标位置如何转换为百度地图坐标
Jul 04 Javascript
浅谈JS继承_寄生式继承 & 寄生组合式继承
Aug 16 Javascript
微信小程序 wxapp画布 canvas详细介绍
Oct 31 Javascript
vue axios 二次封装的示例代码
Dec 08 Javascript
Angular-UI Bootstrap组件实现警报功能
Jul 16 Javascript
js限制输入框只能输入数字(onkeyup触发)
Sep 28 Javascript
koa源码中promise的解读
Nov 13 Javascript
微信小程序授权登陆及每次检查是否授权实例代码
Sep 18 Javascript
Vue解决echart在element的tab切换时显示不正确问题
Aug 03 Javascript
JS遍历ul下的li点击弹出li的索引的实现方法
Sep 19 #Javascript
vuejs在解析时出现闪烁的原因及防止闪烁的方法
Sep 19 #Javascript
javascript 判断页面访问方式电脑或者移动端
Sep 19 #Javascript
详解Node.Js如何处理post数据
Sep 19 #Javascript
React Native实现简单的登录功能(推荐)
Sep 19 #Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
Sep 19 #Javascript
BootStrap入门教程(二)之固定的内置样式
Sep 19 #Javascript
You might like
《PHP编程最快明白》第七讲:php图片验证码与缩略图
2010/11/01 PHP
PHP连接MSSQL时nvarchar字段长度被截断为255的解决方法
2014/12/25 PHP
Zend Framework生成验证码并实现验证码验证功能(附demo源码下载)
2016/03/22 PHP
Yii2框架数据验证操作实例详解
2018/05/02 PHP
javascript 建设银行登陆键盘
2008/06/10 Javascript
Javascript 布尔型分析
2008/12/22 Javascript
JavaScript日历实现代码
2010/09/12 Javascript
22点关于jquery性能优化的建议
2014/05/28 Javascript
jQuery实现ctrl+enter(回车)提交表单
2015/10/19 Javascript
分享Javascript实用方法二
2015/12/13 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
2016/01/27 Javascript
详解js的六大数据类型
2016/12/27 Javascript
Node.js Koa2使用JWT进行鉴权的方法示例
2018/08/17 Javascript
JavaScript 点击触发复制功能实例详解
2018/11/02 Javascript
JS实现网站吸顶条
2020/01/08 Javascript
在Chrome DevTools中调试JavaScript的实现
2020/04/07 Javascript
谈一谈vue请求数据放在created好还是mounted里好
2020/07/27 Javascript
Pipenv一键搭建python虚拟环境的方法
2018/05/22 Python
python面向对象实现名片管理系统文件版
2019/04/26 Python
python flask web服务实现更换默认端口和IP的方法
2019/07/26 Python
django 连接数据库 sqlite的例子
2019/08/14 Python
Python 之 Json序列化嵌套类方式
2020/02/27 Python
解决jupyter notebook 前面书写后面内容消失的问题
2020/04/13 Python
jupyter note 实现将数据保存为word
2020/04/14 Python
浅析python 定时拆分备份 nginx 日志的方法
2020/04/27 Python
纯CSS打造(无图像无js)的非常流行的讲话(语音)气泡效果
2012/12/28 HTML / CSS
美国领先的水果篮送货公司和新鲜水果供应商:The Fruit Company
2018/02/13 全球购物
三星加拿大官方网上商店:Samsung CA
2020/12/18 全球购物
导游的职业规划书范文
2013/12/27 职场文书
高三英语教学反思
2014/01/13 职场文书
政府门卫岗位职责
2014/04/29 职场文书
求职自我评价范文100字
2014/09/23 职场文书
2014年教育工作总结
2014/11/26 职场文书
老生常谈 使用 CSS 实现三角形的技巧(多种方法)
2021/04/13 HTML / CSS
关于HTML编码导致的乱码问题
2021/09/04 HTML / CSS
redis中lua脚本使用教程
2021/11/01 Redis