前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端基础-ECMAScript箭头函数

前端基础-ECMAScript箭头函数

作者头像
cwl_java
发布2020-03-26 16:21:18
2260
发布2020-03-26 16:21:18
举报
文章被收录于专栏:cwl_Javacwl_Java

第10章 箭头函数

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

10.1 语法

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

代码语言:javascript
复制
var f1 = a=>a;
//相当于  var f1 = function(a){ return a;};
console.log(f1('hello'));//'hello'

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

代码语言:javascript
复制
var f2 = () => '来了老弟';
console.log(f2());

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

代码语言:javascript
复制
var f3 = (a, b) => a+b;
console.log(f3(3,4));//7

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

代码语言:javascript
复制
var f4 = (a, b) => {
  	console.log('来了老弟');
  	return a+b;
}
console.log(f4(5,6));//11

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

代码语言:javascript
复制
var f5 = () => {
  	return ({"name":"老弟", "age":40});
}

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

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

代码语言:javascript
复制
<input type="button" value="点击" id="btn">
<script>
	document.getElementById('btn').onclick = evt=>{
      	console.log(evt);//evt 事件对象
	}
</script>

7.赋值为对象的方法

代码语言:javascript
复制
var obj = {};
obj.say = ()=>{return "hello,我是obj的say方法";}
console.log(obj.say());

8.作为回调函数

代码语言:javascript
复制
var f6 = (f)=>{
    console.log(f(100));
};
// f6(a=>a);
var f7 = a=>a;
f6(f7);

10.2 注意点

  1. typeof 判断箭头函数 结果为function
代码语言:javascript
复制
var f1 = a=>a;
console.log(typeof f1);//'function'
  1. instanceof判断是否Function的实例,结果为true
代码语言:javascript
复制
var f1 = a=>a;
console.log(f1 instanceof Function);//true
  1. 箭头函数不绑定this, 内外this指向固定不变

这个很有用,再不用写me,self,_this了,或者bind。

代码语言:javascript
复制
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();
  1. 箭头函数不能做构造函数,不能用new实例化,也没有prototype属性
代码语言:javascript
复制
var Person = ()=>{};
console.log(Person.prototype);//undefined
var p = new Person();//报错
  1. 不能使用arguments
代码语言:javascript
复制
var f1 = ()=>{
	console.log(arguments);
};
f1(); //报错

6.箭头函数也支持默认参数、剩余参数、解构

代码语言:javascript
复制
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]);
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 第10章 箭头函数
    • 10.1 语法
      • 10.2 注意点
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档