面试-this指向问题的应用

一、x到底是谁?

function a(xx){
	this.x = xx;
	return this
};
var x = a(5);
var y = a(6);

console.log(x.x)  // undefined
console.log(y.x)  // 6
  • 我们会判断错误的可能原因是被变量名x误导.

分析

this指向调用方法的环境,所以window为本例子中的this

  • var x = a(5)

    • 执行右半部分
      a(5),this.x = xx相当于window.x=xx
      也就是说当前windox.x = 5
      然后返回window本身。
    • 执行赋值
      相当于重新定义了x,此刻window.x = a(5)的返回值window
    • 测试输出
      console.log(x.x)打印出window
  • var y=a(6)

    • 执行右半部分
      a(6),this.x = xx相当于window.x=xx
      也就是说当前windox.x = 6
      然后返回window本身。
    • 执行赋值
      此刻window.y = a(6)的返回值window
    • 测试输出
      console.log(x.x)打印出undefined,因为x.x等价6.x,结果自然为undefined
      console.log(y.x)打印6
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值