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 相关文章推荐
JavaScript之HTMLCollection接口代码
Apr 27 Javascript
Jquery异步请求数据实例代码
Dec 28 Javascript
js获取html页面节点方法(递归方式)
Dec 13 Javascript
javascript设计模式之中介者模式Mediator
Dec 30 Javascript
javascript日期格式化方法汇总
Oct 04 Javascript
Vue.js实战之通过监听滚动事件实现动态锚点
Apr 04 Javascript
React Native自定义控件底部抽屉菜单的示例
Feb 08 Javascript
三分钟学会用ES7中的Async/Await进行异步编程
Jun 14 Javascript
小程序清理本地缓存的方法
Aug 17 Javascript
vue 点击按钮增加一行的方法
Sep 07 Javascript
layer父页获取弹出层输入框里面的值方法
Sep 02 Javascript
0基础学习前端开发的一些建议
Jul 14 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按单词截取字符串的方法
2015/04/07 PHP
解析WordPress中控制用户登陆和判断用户登陆的PHP函数
2016/03/01 PHP
yii框架搜索分页modle写法
2016/12/19 PHP
aspx中利用js实现确认删除代码
2010/07/22 Javascript
推荐17个优美新鲜的jQuery的工具提示插件
2012/09/14 Javascript
使用GruntJS链接与压缩多个JavaScript文件过程详解
2013/08/02 Javascript
Jquery 例外被抛出且未被接住原因介绍
2013/09/04 Javascript
根据配置文件加载js依赖模块
2014/12/29 Javascript
6种javascript显示当前系统时间代码
2015/12/01 Javascript
JS实现动态生成表格并提交表格数据向后端
2020/11/25 Javascript
微信JS SDK接入的几点注意事项(必看篇)
2017/06/23 Javascript
基于vue.js 2.x的虚拟滚动条的示例代码
2018/01/23 Javascript
vue2.0模拟锚点的实例
2018/03/14 Javascript
AngularJs返回前一页面时刷新一次前面页面的方法
2018/10/09 Javascript
js实现黑白div块画空心的图形
2018/12/13 Javascript
ES6 Promise对象的含义和基本用法分析
2019/06/14 Javascript
编程语言Python的发展史
2014/09/26 Python
python插入数据到列表的方法
2015/04/30 Python
Windows下使Python2.x版本的解释器与3.x共存的方法
2015/10/25 Python
python 爬取微信文章
2016/01/30 Python
Python 实现文件的全备份和差异备份详解
2016/12/27 Python
Python面向对象之静态属性、类方法与静态方法分析
2018/08/24 Python
基于python生成器封装的协程类
2019/03/20 Python
Numpy数组的广播机制的实现
2020/11/03 Python
Python在后台自动解压各种压缩文件的实现方法
2020/11/10 Python
python实现视频压缩功能
2020/12/18 Python
让IE9以下版本的浏览器兼容HTML5的方法
2014/03/12 HTML / CSS
英国领先的品牌珠宝和配件供应商:Acotis Jewellery
2018/03/07 全球购物
我想声明一个指针并为它分配一些空间, 但却不行。这些代码有什么 问题?char *p; *p = malloc(10);
2016/10/06 面试题
WEB控件及HTML服务端控件能否调用客户端方法?如果能,请解释如何调用?
2015/08/25 面试题
函授本科自我鉴定
2013/11/03 职场文书
工厂厂长岗位职责
2013/11/08 职场文书
八一建军节活动方案
2014/02/10 职场文书
师德先进个人材料
2014/12/20 职场文书
2015年百日安全活动总结
2015/03/26 职场文书
python三子棋游戏
2022/05/04 Python