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 相关文章推荐
汉化英文版的Dreamweaver CS5并自动提示jquery
Nov 25 Javascript
javascript和HTML5利用canvas构建猜牌游戏实现算法
Jul 17 Javascript
使用js画图之画切线
Jan 12 Javascript
js中javascript:void(0) 真正含义
Nov 05 Javascript
Bootstrap树形组件jqTree的简单封装
Jan 25 Javascript
javascript url几种编码方式详解
Jun 06 Javascript
微信小程序 教程之列表渲染
Oct 18 Javascript
利用Node.JS实现邮件发送功能
Oct 21 Javascript
JavaScript基本类型值-Undefined、Null、Boolean
Feb 23 Javascript
浅谈事件冒泡、事件委托、jQuery元素节点操作、滚轮事件与函数节流
Jul 22 jQuery
如何理解Vue的render函数的具体用法
Aug 30 Javascript
详解vue-cli3多页应用改造
Jun 04 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笔记 字符串处理
2010/10/19 PHP
php文件上传表单摘自drupal的代码
2011/02/15 PHP
php中异常处理方法小结
2015/01/09 PHP
php加密之discuz内容经典加密方式实例详解
2017/02/04 PHP
实例说明js脚本语言和php脚本语言的区别
2019/04/04 PHP
PHP使用ajax的post方式下载excel文件简单示例
2019/08/06 PHP
js监听键盘事件示例代码
2013/07/26 Javascript
JS正则表达式验证数字代码
2014/01/28 Javascript
Javascript前端UI框架Kit使用指南之Kitjs简介
2014/11/28 Javascript
写给小白的JavaScript引擎指南
2015/12/04 Javascript
深入理解bootstrap框架之第二章整体架构
2016/10/09 Javascript
Angularjs之filter过滤器(推荐)
2016/11/27 Javascript
彻底学会Angular.js中的transclusion
2017/03/12 Javascript
JavaScript设计模式之调停者模式实例详解
2018/02/03 Javascript
Vue项目中跨域问题解决方案
2018/06/05 Javascript
命令行批量截图Node脚本示例代码
2019/01/25 Javascript
监控Nodejs的性能实例代码
2019/07/02 NodeJs
vue + axios get下载文件功能
2019/09/25 Javascript
JavaScript中this的学习笔记及用法整理
2020/02/17 Javascript
Vue之封装公用变量以及实现方式
2020/07/31 Javascript
Taro小程序自定义顶部导航栏功能的实现
2020/12/17 Javascript
python2与python3的print及字符串格式化小结
2018/11/30 Python
Python3安装pip工具的详细步骤
2019/10/14 Python
Python操作MongoDb数据库流程详解
2020/03/05 Python
python转化excel数字日期为标准日期操作
2020/07/14 Python
PyCharm 2020.2.2 x64 下载并安装的详细教程
2020/10/15 Python
印度尼西亚在线时尚购物网站:ZALORA印尼
2016/08/02 全球购物
Smallable意大利家庭概念店:设计师童装及家居装饰
2018/01/08 全球购物
string = null 和string = ''的区别
2013/04/28 面试题
大二自我鉴定范文
2013/10/05 职场文书
实习自我评价怎么写
2013/12/02 职场文书
2014年食堂工作总结
2014/11/20 职场文书
2016年大学迎新晚会工作总结
2015/10/15 职场文书
合作合同协议书
2016/03/21 职场文书
详解Python小数据池和代码块缓存机制
2021/04/07 Python
工厂无线对讲系统解决方案
2022/02/18 无线电