27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]
E-mail:mzze@163.com
Q Q:32362389
W X:xiaomi168527
27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]
大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]
E-mail:97157726@qq.com
Q Q:97157726
ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器)。
var f1 = a=>a; //相当于 function f(a){ return a; }
var f2 = () => '来了老弟'; console.log(f2()); //相当于 function f2() { return '来了老弟'; }
var f3 = (a, b) => a+b; console.log(f3(3,4));//7
var f4 = (a, b) => { console.log('来了老弟'); return a+b; } console.log(f4(5,6));//11
var f5 = () => { return ({"name":"老弟", "age":40}); } //var f5 = () => ({"name":"老弟", "age":40}); console.log(f5());
<input type="button" value="点击" id="btn"> <script> document.getElementById('btn').onclick = evt=>{ console.log(evt);//evt 事件对象 } </script>
var obj = {}; obj.say = ()=>{return "hello,我是obj的say方法";} console.log(obj.say());
var f6 = (f)=>{ console.log(f(100)); }; // f6(a=>a); var f7 = a=>a; f6(f7);
1. typeof 判断箭头函数 结果为function
var f1 = a=>a; console.log(typeof f1);//'function'
2. instanceof 判断结果为true 箭头函数也是Function构造函数的实例
var f1 = a=>a; console.log(f1 instanceof Function);//true
3. 箭头函数不绑定this, 内外this指向固定不变
这个很有用,再不用写me,self,_this了,或者bind。
var obj = { say:function(){ //非箭头函数 var _this = this; var f1 = function(){ console.log(_this);//obj console.log(this);//window }; f1(); //箭头函数 var f2 = ()=>{ console.log(this); }; f2(); } }; obj.say();
4. 箭头函数不能做构造函数,不能用new实例化,也没有prototype属性
var Person = ()=>{}; console.log(Person.prototype);//undefined var p = new Person();//报错
5. 不能使用arguments
var f1 = ()=>{ console.log(arguments); }; f1(); //报错
6.箭头函数也支持默认参数、剩余参数、解构
var f1 = (x=1,y)=>{ console.log(x, y); //3 4 }; f1(3,4); var f2 = (...x)=>{ console.log(x); //[3,4] }; f2(3,4); var f3 = ([x,y]=[])=>{ console.log(x, y); //3 4 }; f3([3,4]);
本站内容均为小米原创,转载请注明出处:小米技术社区>> ES6的箭头函数=>用法和注意事项