JavaScript——箭头函数

箭头函数

javascript中箭头函数类似于Java中的lambda表达式,这种函数的出现大大简化了函数的定义:
传统函数:

<script>
	function add(a,b){
	return a+b;
	}
	console.log(add(1,1));
</script>

箭头函数:

<script>
	var add=(a,b)=>{//类似于变量式定义方法。
		return a+b;
	}
	console.log(add(1,1));
</script>

在这里插入图片描述
注意:
a、如果函数体只有一行代码,则函数大括号可以省略,如果该行代码用于返回结果,return必须忽略,如下例子:
1,return必须省略

<script>
	var add=(a,b)=>a+b;	//只有一行代码,return必须可以省略。
	console.log(add(1,1));
</script>

2,一行代码为输出时

<script>
	var add=(a,b)=>console.log(a+b);
	add(2,3)
</script>

在这里插入图片描述
b、箭头函数是匿名函数,不能作为构造函数,不能使用new,如下例子:

<script>
	let Student = () => {
	 console.log('箭头函数不能作为构造函数');
	}
	
	let student = new Student();
</script>

在这里插入图片描述
c、箭头函数没有原型属性,如下例子:

<script>
	var add = (a, b) => a + b;
	console.log(add.prototype); // undefined

	function print() {
		console.log("Tom");
	}
	console.log(print.prototype);
</script>

在这里插入图片描述
d、箭头函数不绑定arguments,而是使用…接收不定参数,如下例子:

<script>
	function print(params){//普通方法
		console.log(arguments);
	}
	print(1,2,3,4,5);
</script>

在这里插入图片描述

<script>
	let print=(params)=>console.log(arguments)	//箭头函数
	print(1,2,3);
</script>

在这里插入图片描述

<script>
	var print=(...params)=>console.log(params);//箭头函数
	print(1,3,5,7,9);
</script>

在这里插入图片描述
e、箭头函数中this永远指向其上下文中的this,普通函数中this指向调用它的对象,如下代码:

<script>
	var student = {
		age: 10,
		a: function() {
			console.log(this); // Object { age: 10, a: a(), b: b(), c: c() }
			console.log(this.age); // 10
		},
		b: () => {
			console.log(this); // Window
			console.log(this.age); // undefined
		},
		c: function() {
			return() => {
				console.log(this);//Object { age: 10, a: a(), b: b(), c: c() }
				console.log(this.age); //10
			}
		}
	}
	student.a();
	student.b();
	student.c()();
</script>

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值