__call__()和call的区别_this指向和apply,call,bind三者的区别

一、前言

this指向,apply,call,bind的区别是一个经典的面试问题,同时在项目中会经常使用到的原生的js方法。同时也是ES5中的众多坑的一个。ES6中可能会极大的避免了this产生的错误,有时候需要维护老的项目还是有必要了解一下this的指向和apply,call,bind三者的区别。

a4b865544ebc6fea503d19f3944d16e6.png

二、this的指向

在ES5中,其实this的指向,始终坚持一个原理:this永远指向最后一个调用它的那个对象

首先我们看一个栗子1:

var name = "windowsName";function a() { var name = "Cherry"; console.log(this.name); // windowsName console.log("inner:" + this); // inner: Window}a();console.log("outer:" + this) // outer: Window

输出windowsName,是因为“this永远指向最后调用它的那个对象”,我们看到调用a的地方a(),前面没有调用的对象那么就是全局对象window,就是全局对象调用a(),相当于window.a()。

如果使用严格模式,全局对象就是undefined,会报错name of undefined

栗子2:

var name = "windowsName";var a = { name: "Cherry
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值