小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
  • 什么是闭包?js闭包的2个最大用途以及注意事项

    什么是闭包?js闭包的2个最大用途以及注意事项

    各种专业文献上的"闭包"(closure)定义非常抽象,很难看懂。简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因……
    134人已经看过了
您的位置:首页 > 前端开发 > Javascript > 原生JS

ES6的箭头函数=>用法和注意事项

分类: 原生JS40个赞

ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器)。


1.具有一个参数并直接返回的函数


var f1 = a=>a;
//相当于  
function f(a){
        return a;
    }



2.没有参数的需要用在箭头前加上小括号


var f2 = () => '来了老弟';
console.log(f2());

//相当于
function f2() {
            return '来了老弟';
        }


3.多个参数需要用到小括号,参数间逗号间隔


var f3 = (a, b) => a+b;
console.log(f3(3,4));//7



4.函数体多条语句需要用到大括号


var f4 = (a, b) => {
    console.log('来了老弟');
    return a+b;
}
console.log(f4(5,6));//11





5.返回对象时需要用小括号包起来,因为大括号被占用解释为代码块


var f5 = () => {
    return ({"name":"老弟", "age":40});
}

//var f5 = () => ({"name":"老弟", "age":40});
console.log(f5());





6.直接作为事件处理函数用法


<input type="button" value="点击" id="btn">
<script>
    document.getElementById('btn').onclick = evt=>{
        console.log(evt);//evt 事件对象
    }
</script>




7.赋值为对象的方法


var obj = {};
obj.say = ()=>{return "hello,我是obj的say方法";}
console.log(obj.say());



8.作为回调函数

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的箭头函数=>用法和注意事项