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 相关文章推荐
用js实现下载远程文件并保存在本地的脚本
May 06 Javascript
Jquery获取复选框被选中值的简单方法
Jul 04 Javascript
javascript获取浏览器类型和版本的方法(js获取浏览器版本)
Mar 13 Javascript
jQuery点击弹出层弹出模态框点击模态框消失代码分享
Jan 21 Javascript
AngularJS解决ng-if中的ng-model值无效的问题
Jun 21 Javascript
解决vue的变量在settimeout内部效果失效的问题
Aug 30 Javascript
微信小程序 搜索框组件代码实例
Sep 06 Javascript
Vue.set 全局操作简单示例
Sep 19 Javascript
vue实现吸顶、锚点和滚动高亮按钮效果
Oct 21 Javascript
vue transition 在子组件中失效的解决
Nov 12 Javascript
d3.js 地铁轨道交通项目实战
Nov 27 Javascript
python虚拟环境 virtualenv的简单使用
Jan 21 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程序之die调试法 快速解决错误
2009/09/17 PHP
php 处理上百万条的数据库如何提高处理查询速度
2010/02/08 PHP
本地机apache配置基于域名的虚拟主机详解
2013/08/10 PHP
PHP中把有符号整型转换为无符号整型方法
2015/05/27 PHP
ThinkPHP表单数据智能写入create方法实例分析
2015/09/27 PHP
Smarty实现页面静态化(生成HTML)的方法
2016/05/23 PHP
Laravel5.1自定义500错误页面示例
2016/10/09 PHP
PHP 微信扫码支付源代码(推荐)
2016/11/03 PHP
删除PHP数组中的重复元素的实现代码
2017/04/10 PHP
一段好玩的JavaScript代码
2006/12/01 Javascript
jQuery 页面 Mask实现代码
2010/01/09 Javascript
jquery实现超简洁的TAB选项卡效果代码
2015/08/28 Javascript
javascript下拉列表菜单的实现方法
2015/11/18 Javascript
详解JavaScript for循环中发送AJAX请求问题
2020/06/23 Javascript
基于JavaScript实现 网页切出 网站title变化代码
2016/04/03 Javascript
JS递归遍历对象获得Value值方法技巧
2016/06/14 Javascript
深入浅析JavaScript中的scrollTop
2016/07/11 Javascript
玩转NODE.JS(四)-搭建简单的聊天室的代码
2016/11/11 Javascript
Node.js通过身份证号验证年龄、出生日期与性别方法示例
2017/03/09 Javascript
JS弹窗 JS弹出DIV并使整个页面背景变暗功能的实现代码
2018/04/21 Javascript
jQuery实现的点击显示隐藏下拉菜单功能完整示例
2019/05/17 jQuery
基于JS实现一个随机生成验证码功能
2019/05/29 Javascript
JS 遍历 json 和 JQuery 遍历json操作完整示例
2019/11/11 jQuery
JS实现轮播图效果
2020/01/11 Javascript
JavaScript 双向链表操作实例分析【创建、增加、查找、删除等】
2020/04/28 Javascript
原生小程序封装跑马灯效果
2020/10/21 Javascript
ant design pro中可控的筛选和排序实例
2020/11/17 Javascript
[05:17]DOTA2睡衣妹卖萌求签名 CJ第二天全明星影像
2013/07/28 DOTA
python 中的list和array的不同之处及转换问题
2018/03/13 Python
Python3编码问题 Unicode utf-8 bytes互转方法
2018/10/26 Python
欧洲最大的球衣网上商店:Kitbag
2017/11/11 全球购物
联谊活动策划书
2014/01/26 职场文书
党员公开承诺践诺书
2014/03/25 职场文书
学校标语大全
2014/06/19 职场文书
2014年优秀班主任工作总结
2014/12/16 职场文书
openEuler 搭建java开发环境的详细过程
2022/06/10 Servers