美文网首页
2019-01-07/this原理和使用

2019-01-07/this原理和使用

作者: 阿九_beta | 来源:发表于2019-01-09 21:04 被阅读0次

this的原理

先来看一下下面的例子:

var obj = {
  foo: function () {console.log(this.bar)},
  bar: 1
}
 var foo = obj.foo
 var bar = 2
 
 obj.foo()  //1
 foo()   //2

为什么执行obj.foo()和foo()会输出不同的结果呢?查看很多关于this的定义,会有这样的解释:this指的是函数运行时所在的环境。
在上面的例子中:对于obj.foo()来说,foo运行在obj环境,所以this指向obj;对于foo()来说,foo运行在全局环境,所以this指向全局环境。所以,两者的运行结果不一样。

其实造成这种不同的输出结果是因为内存的数据结构。上面的例子其实存储的形式是:


Jietu20190109-183250.jpg

我们来看下两种执行有什么不同:
1.在全局中执行foo()/ 单独执行foo(), this指向2


2.在obj环境中执行obj.foo(),this指向1


2.jpg

this 的使用

1.纯粹的函数调用

var x = 2;
function test() {
  this.x = 1;
  console.log(this) //默认指向object window
}

test() //test函数通过this.x将全局变量x的值由2改为1
console.log(x)  // 2 

2.作为对象方向调用
见例子“2.在obj环境中执行obj.foo(),this指向1”

3.作为构造函数使用
所谓构造函数,就是通过这个函数生成一个新对象(object)。这时,this就指这个新对象

var x = 2;
function test() {
  this.x = 1;
}

var newobj = new test(); //通过关键字new生产新对象newobj, 此时this指向新对象newobj
x  // 2  全局变量x仍是2

4.call() / apply() 调用
apply()/apply()是函数的一个方法,作用是改变函数的调用对象。它的第一个参数就表示改变后的调用这个函数的对象。因此,这时this指的就是这第一个参数。

fn.call(context, param1, param2...)

fn.apply(context, paramArray)

context就是表示fn指向的环境,如果不传入,就默认为全局对象。
例子:

var x = 0;
function test() {
 console.log(this.x);
}

var obj = {};
obj.x = 1;
obj.m = test;
obj.m.apply(obj) // 1
obj.m.apply() //0 默认全局

相关文章

  • 2019-01-07/this原理和使用

    this的原理 先来看一下下面的例子: 为什么执行obj.foo()和foo()会输出不同的结果呢?查看很多关于t...

  • Ubuntu定时任务

    2019-01-07参考网址首先确定是否开启或者安装使用 Cron 实现计划任务 使用的这个模块叫做corn先安装...

  • JsBridge使用和原理

    What is JsBridge 近期在做一个项目,使用的是Native+H5的方式实现的。众所周知的是在Andr...

  • IntentService原理和使用

    IntentService作用 在一个服务中开启一个子线程,处理异步事件,处理完只有关闭自己 IntentServ...

  • HandlerThread原理和使用

    HandlerThread作用 为方便我们在安卓线程间通信,像在主线程一样使用子线程,不用我们自己手动的去调用Lo...

  • pjax原理和使用

    原文:https://www.fanhaobai.com/2017/07/pjax.html pjax 即 pus...

  • ButterKnife使用和原理

    俗话说的好“不想偷懒的程序员,不是好程序员”,我们在日常开发android的过程中,在前端activity或者fr...

  • JsBridge使用和原理

    What is JsBridge 近期在做一个项目,使用的是Native+H5的方式实现的。众所周知的是在Andr...

  • RunTime原理和使用

    原理:消息转发:在一个实例里边使用resolveInstanceMethod方法,内部动态添加一个方法class_...

  • Aspects原理和使用

    前言 在读这篇文章之前,需要对Runtime消息发送、消息转发有一定的了解。Runtime系列Objective-...

网友评论

      本文标题:2019-01-07/this原理和使用

      本文链接:https://www.haomeiwen.com/subject/qgrukqtx.html