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 读取XML数据,在页面中展现、编辑、保存的实现
Oct 27 Javascript
jq选项卡鼠标延迟的插件实例
May 13 Javascript
JavaScript实现随机替换图片的方法
Apr 16 Javascript
使用Node.js为其他程序编写扩展的基本方法
Jun 23 Javascript
jQuery+Ajax实现无刷新分页
Oct 30 Javascript
jQuery版本升级踩坑大全
Jan 12 Javascript
jQuery插件formValidator实现表单验证
May 23 Javascript
JS判断字符串变量是否含有某个字串的实现方法
Jun 03 Javascript
jQuery弹出下拉列表插件(实现kindeditor的@功能)
Aug 16 Javascript
d3.js入门教程之数据绑定详解
Apr 28 Javascript
Vue中插入HTML代码的方法
Sep 21 Javascript
vue打包npm run build时候界面报错的解决
Aug 13 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
php4的彩蛋
2006/10/09 PHP
初次接触php抽象工厂模式(Elgg)
2010/03/21 PHP
基于wordpress主题制作的具体实现步骤
2013/05/10 PHP
php读取文件内容到数组的方法
2015/03/16 PHP
codeigniter中view通过循环显示数组数据的方法
2015/03/20 PHP
Thinkphp 框架扩展之标签库驱动原理与用法分析
2020/04/23 PHP
Jquery中获取iframe的代码
2011/01/11 Javascript
定义JavaScript二维数组采用定义数组的数组来实现
2012/12/09 Javascript
javascript操作css属性
2013/12/30 Javascript
JS操作XML实例总结(加载与解析XML文件、字符串)
2015/12/08 Javascript
Bootstrap项目实战之子栏目资讯内容
2016/04/25 Javascript
Bootstrap每天必学之轮播(Carousel)插件
2016/04/25 Javascript
Bootstrap DateTime Picker日历控件简单应用
2017/03/25 Javascript
微信小程序 动态绑定事件并实现事件修改样式
2017/04/13 Javascript
详解使用VueJS开发项目中的兼容问题
2018/08/02 Javascript
使用Karma做vue组件单元测试的实现
2020/01/16 Javascript
vue实现信息管理系统
2020/05/30 Javascript
2款Python内存检测工具介绍和使用方法
2014/06/01 Python
独特的python循环语句
2016/11/20 Python
python下读取公私钥做加解密实例详解
2017/03/29 Python
利用python写个下载teahour音频的小脚本
2017/05/08 Python
Python使用plotly绘制数据图表的方法
2017/07/18 Python
Python编程实现从字典中提取子集的方法分析
2018/02/09 Python
详解Django rest_framework实现RESTful API
2018/05/24 Python
详解python算法之冒泡排序
2019/03/05 Python
python爬虫简单的添加代理进行访问的实现代码
2019/04/04 Python
Python面向对象程序设计多继承和多态用法示例
2019/04/08 Python
pytorch自定义初始化权重的方法
2019/08/17 Python
python+tkinter实现学生管理系统
2019/08/20 Python
python GUI库图形界面开发之PyQt5窗口类QMainWindow详细使用方法
2020/02/26 Python
python中requests模拟登录的三种方式(携带cookie/session进行请求网站)
2020/11/17 Python
CSS3线性渐变简单实现以及该属性在浏览器中的不同
2012/12/12 HTML / CSS
小学生学习感言
2014/03/10 职场文书
学雷锋活动总结报告
2014/06/26 职场文书
小学美术教学反思
2016/02/17 职场文书
中国式结婚:司仪主持词(范文)
2019/07/25 职场文书