javascript中的this作用域详解


Posted in Javascript onJuly 15, 2019

Javascript中this的指向一直是困扰我很久的问题,在使用中出错的机率也非常大。在面向对象语言中,它代表了当前对象的一个引用,而在js中却经常让我觉得混乱,它不是固定不变的,而是随着它的执行环境的改变而改变。

在Javascript中this总是指向调用它所在方法的对象。因为this是在函数运行时,自动生成的一个内部对象,只能在函数内部使用。

下面我们分几种情况深入分析this的用法:

1.全局的函数调用

function globalTest() {
    this.name = "global this";
    console.log(this.name);
  }
  globalTest(); //global this

以上代码中,globalTest()是全局性的方法,属于全局性调用,因此this就代表全局对象window。为了充分证明this是window,对代码做如下更改:

var name = "global this";

  function globalTest() {
    console.log(this.name);
  }
  globalTest(); //global this

name作为一个全局变量,运行结果仍然是“global this”,说明this指向的是window。在方法体中我们尝试更改全局name,再次调用方法输出“rename global this”, 说明全局的name在方法内部被更改。代码如下:

var name = "global this";

  function globalTest() {
    this.name = "rename global this"
    console.log(this.name);
  }
  globalTest(); //rename global this

根据以上三段代码,我们得出结论:对于全局的方法调用,this指向的是全局对象window,即调用方法所在的对象。

2.对象方法的调用

如果函数作为对象的方法调用,this指向的是这个上级对象,即调用方法的对象。 在以下代码中,this指向的是obj对象。

function showName() {
    console.log(this.name);
  }
  var obj = {};
  obj.name = "ooo";
  obj.show = showName;
  obj.show(); //ooo

3.构造函数的调用

构造函数中的this指向新创建的对象本身。

function showName() {
    this.name = "showName function";
  }
  var obj = new showName();
  console.log(obj.name); //showName function

上述代码中,我们通过new关键字创建一个对象的实例,new关键字可以改变this的指向,将这个this指向对象obj。
我们再增加一个全局的name,用以证明this指向的不是global:

var name = "global name";

  function showName() {
    this.name = "showName function";
  }
  var obj = new showName();

  console.log(obj.name); //showName function
  console.log(name); //global name

在构造函数的内部,我们对this.name进行赋值,但并没有改变全局变量name。

4.apply/call调用时的this

apply和call都是为了改变函数体内部的this指向。 其具体的定义如下:

call方法:

语法:call(thisObj,Object)

定义:调用一个对象的一个方法,以另一个对象替换当前对象。

说明:

call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。

如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法:

语法:apply(thisObj,[argArray])

定义:应用某一对象的一个方法,用另一个对象替换当前对象。

说明:

如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。

如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

var value = "Global value";

  function FunA() {
    this.value = "AAA";
  }

  function FunB() {
    console.log(this.value);
  }
  FunB(); //Global value 因为是在全局中调用的FunB(),this.value指向全局的value
  FunB.call(window); //Global value,this指向window对象,因此this.value指向全局的value
  FunB.call(new FunA()); //AAA, this指向参数new FunA(),即FunA对象

  FunB.apply(window); //Global value
  FunB.apply(new FunA()); //AAA

在上述代码中,this的指向在call和apply中是一致的,只不过是调用参数的形式不一样。call是一个一个调用参数,而apply是调用一个数组。具体的会在以后的博文中单独阐述。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery将文本转化成JSON对象需要注意的问题
May 09 Javascript
JSON+JavaScript处理JSON的简单例子
Mar 20 Javascript
JQuery仿小米手机抢购页面倒计时效果
Dec 16 Javascript
jquery图片播放浏览插件prettyPhoto使用详解
Dec 19 Javascript
JS实现带鼠标效果的头像及文章列表代码
Sep 27 Javascript
js右下角弹出提示框示例代码
Jan 12 Javascript
vue如何实现observer和watcher源码解析
Mar 09 Javascript
基于 Vue.js 2.0 酷炫自适应背景视频登录页面实现方式
Jan 17 Javascript
Vue 自定义动态组件实例详解
Mar 28 Javascript
Vue表情输入组件 微信face表情组件
Feb 11 Javascript
Element-ui树形控件el-tree自定义增删改和局部刷新及懒加载操作
Aug 31 Javascript
Vue中登录验证成功后保存token,并每次请求携带并验证token操作
Sep 08 Javascript
微信小程序页面上下滚动效果
Nov 18 #Javascript
node.js实现上传文件功能
Jul 15 #Javascript
js canvas实现5张图片合成一张图片
Jul 15 #Javascript
js使用文件流下载csv文件的实现方法
Jul 15 #Javascript
基于Taro的微信小程序模板消息-获取formId功能模块封装实践
Jul 15 #Javascript
微信小程序开发技巧汇总
Jul 15 #Javascript
微信小程序中如何计算距离某个节日还有多少天
Jul 15 #Javascript
You might like
非常精妙的PHP递归调用与静态变量使用
2012/12/16 PHP
使用cookie实现统计访问者登陆次数
2013/06/08 PHP
浅析51个PHP处理字符串的函数
2013/08/02 PHP
CI框架自动加载session出现报错的解决办法
2014/06/17 PHP
php获取用户浏览器版本的方法
2015/01/03 PHP
PHP检查URL包含特定字符串实例方法
2019/02/11 PHP
php如何把表单内容提交到数据库
2019/07/08 PHP
对字符串进行HTML编码和解码的JavaScript函数
2010/02/01 Javascript
基于jquery的网页SELECT下拉框美化代码
2010/10/28 Javascript
javascript在IE下trim函数无法使用的解决方法
2014/09/12 Javascript
深入理解javascript原型链和继承
2014/09/23 Javascript
javascript弹性运动效果简单实现方法
2016/01/08 Javascript
详解Javascript继承的实现
2016/03/25 Javascript
解读Bootstrap v4 sass设计
2016/05/29 Javascript
老生常谈JavaScript 正则表达式语法
2016/08/20 Javascript
js学习笔记之事件处理模型
2016/10/31 Javascript
Angular.js基础学习之初始化
2017/03/10 Javascript
js+html5实现页面可刷新的倒计时效果
2017/07/15 Javascript
浅谈express 中间件机制及实现原理
2017/08/31 Javascript
CryptoJS中AES实现前后端通用加解密技术
2018/12/18 Javascript
微信小程序上传图片到php服务器的方法
2019/05/23 Javascript
深入理解JS异步编程-Promise
2019/06/03 Javascript
浅析Vue下的components模板使用及应用
2019/11/27 Javascript
Vue SSR 即时编译技术的实现
2020/05/06 Javascript
python pandas获取csv指定行 列的操作方法
2019/07/12 Python
使用python制作游戏下载进度条的代码(程序说明见注释)
2019/10/24 Python
SmartBuyGlasses台湾:名牌眼镜,名牌太阳眼镜及隐形眼镜
2017/01/04 全球购物
Nayomi官网:沙特阿拉伯王国睡衣和内衣品牌
2020/12/19 全球购物
英国最大的天然和有机产品在线零售商之一:Big Green Smile
2020/05/06 全球购物
大学自荐信
2013/12/12 职场文书
优秀员工自荐书
2013/12/19 职场文书
学生自我评价范文
2014/02/02 职场文书
南京市纪委监察局整改方案
2014/09/16 职场文书
产品委托授权书范本
2014/09/16 职场文书
Redis 哨兵集群的实现
2021/06/18 Redis
mysql 索引合并的使用
2021/08/30 MySQL