博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于ES6 用箭头函数后的 this 指向问题
阅读量:5097 次
发布时间:2019-06-13

本文共 1034 字,大约阅读时间需要 3 分钟。

最近写完小程序后, 开始学习React, 因为有编译器, 就直接用ES6 新语法了,

中间自然离不开  () => { console.log(‘箭头函数的this是指向哪的问题’)};

var obj2 = {    id: 2333,    test: () => console.log(this)}obj2.test();//windowobj2.test.call(obj2);//window

那么我要这里 test函数的this 指向 obj2 是要怎么做呢

来分析下上面代码, 转换成 ES5 写法的this指向: 

var obj2 = {};      // window.obj2 = {};obj2.id = 2333;     // window.obj2 = { id: 2333; }var _this = this;obj2.test = function(){console.log(_this);}

 

用箭头函数时, this是指向 最初定义变量时的this, 即 window.obj2 的 window

改一下, 变得很复杂了

var obj2 = {           id: 2333,        test: function(){            (()=>{                console.log(this)            })()        }    }    obj2.test();//obj2    obj2.test.call(obj2);//obj2

其实还有一种写法:

function Obj(){    this.id = 2333;    this.test = () => console.log(this);}var obj2 = new Obj();

**************************************************

总结: 

 1. 箭头函数的this不能用call()或者apply()进行绑定

 2. 箭头函数的 this 永远指向该函数构造时的环境。

...  现在还没再nodeJs环境中 用箭头函数, 只知道 浏览器的顶级对象是 window, node环境是 global , 后面深入学习node之后再总结..

 

转载于:https://www.cnblogs.com/qq4535292/p/8057772.html

你可能感兴趣的文章
EF搭建数据库
查看>>
【并发】使用synchronized获取互斥锁的几点说明
查看>>
JS阻止事件冒泡的3种方法之间的不同
查看>>
cocos2dx CCSprite CCLayer 游戏基础
查看>>
Codeforces 348
查看>>
第40节:Java中的IO知识案例
查看>>
PHP全栈学习笔记16
查看>>
计算最长单词链
查看>>
IOS 自定义Operation(下载功能)
查看>>
存储管理
查看>>
OSC的原理
查看>>
数据库范式
查看>>
VC6.0调试技巧(一)(转)
查看>>
用Chrome调试Android手机上的网页
查看>>
django 王中王8之踏青撒花
查看>>
学习网站收集
查看>>
Qt调用摄像头(截取并保存图片)
查看>>
linux命令
查看>>
类库与框架,强类型与弱类型的闲聊
查看>>
webView添加头视图
查看>>