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 相关文章推荐
关于UTF-8的客户端用AJAX方式获取GB2312的服务器端乱码问题的解决办法
Nov 30 Javascript
jQuery中:checked选择器用法实例
Jan 04 Javascript
javascript定时器完整实例
Feb 10 Javascript
Jquery实现鼠标移动放大图片功能实例
Mar 25 Javascript
JS实现点击按钮后框架内载入不同网页的方法
May 05 Javascript
JavaScript、C# URL编码、解码总结
Jan 21 Javascript
解决URL地址中的中文乱码问题的办法
Feb 10 Javascript
Vue中的v-cloak使用解读
Mar 27 Javascript
vue.js移动端app实战1:初始配置详解
Jul 24 Javascript
微信小程序支付功能 php后台对接完整代码分享
Jun 12 Javascript
在vue中多次调用同一个定义全局变量的实例
Sep 25 Javascript
inquirer.js一个用户与命令行交互的工具详解
May 18 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
全国FM电台频率大全 - 7 吉林省
2020/03/11 无线电
PHP Session机制简介及用法
2014/08/19 PHP
php编写的一个E-mail验证类
2015/03/25 PHP
laravel 5.4中实现无限级分类的方法示例
2017/07/27 PHP
PHP实现验证码校验功能
2017/11/16 PHP
Laravel+Intervention实现上传图片功能示例
2019/07/09 PHP
使用Jquery获取带特殊符号的ID 标签的方法
2014/04/30 Javascript
创建、调用JavaScript对象的方法集锦
2014/12/24 Javascript
分享10个原生JavaScript技巧
2015/04/20 Javascript
ECMAScript6函数默认参数
2015/06/12 Javascript
详解AngularJS实现表单验证
2015/12/10 Javascript
阿里巴巴技术文章分享 Javascript继承机制的实现
2016/01/14 Javascript
jQuery中通过ajax的get()函数读取页面的方法
2016/02/29 Javascript
JS实现iframe自适应高度的方法(兼容IE与FireFox)
2016/06/24 Javascript
Angular的自定义指令以及实例
2016/12/26 Javascript
vuex中的 mapState,mapGetters,mapActions,mapMutations 的使用
2018/04/13 Javascript
jQuery中each遍历的三种方法实例分析
2018/09/07 jQuery
微信小程序可滑动月日历组件使用详解
2019/10/21 Javascript
JavaScript数值类型知识汇总
2019/11/17 Javascript
vue3.0 自适应不同分辨率电脑的操作
2021/02/06 Vue.js
[00:32]2018DOTA2亚洲邀请赛iG出场
2018/04/03 DOTA
按日期打印Python的Tornado框架中的日志的方法
2015/05/02 Python
Python使用turtule画五角星的方法
2015/07/09 Python
python 实现对文件夹内的文件排序编号
2018/04/12 Python
详解TensorFlow查看ckpt中变量的几种方法
2018/06/19 Python
Python子类继承父类构造函数详解
2019/02/19 Python
Python缓存技术实现过程详解
2019/09/25 Python
MAC彩妆澳洲官网:M·A·C AU
2021/01/17 全球购物
违章停车检讨书
2014/10/21 职场文书
2015年度党员个人总结
2015/02/14 职场文书
继续教育个人总结
2015/03/03 职场文书
员工升职自荐信
2015/03/27 职场文书
自信主题班会
2015/08/14 职场文书
班干部学习委员竞选稿
2015/11/20 职场文书
JS数组方法some、every和find的使用详情
2021/10/05 Javascript
Oracle删除归档日志及添加定时任务
2022/06/28 Oracle