JavaScript - THIS经典案例分析

var num = 10;
var obj = {num:20};
obj.fn = (function(num){
	this.num = num * 3;
	num++;
	return function(n){
		this.num += n;
		num++;
		console.log(num);
	};
})(obj.num);
var fn = obj.fn;
fn(5);
fn(10);
console.log(num, obj.num);

图形解析:请添加图片描述

  • 函数每执行一次,就会形成一个全新的上下文,多次执行产生的上下文没有必然的关系。
  • 普通函数函数执行,先看前面有没有点(.):
    • 有点,点前面是谁this就是谁;
    • 没有点。this就是window,严格模式是undefined。
window.val = 1;
var json = {
    val :10,
    dbl :function(){
        this.val *=2;
    }
};
json.dbl();
var dbl = json.dbl;
dbl();
json.dbl.call(window);

图形解析:请添加图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值