ECMAScript6语法:箭头函数

在 ES6 中,可以使用箭头"=>"定义函数。根据不同的使用场景,箭头函数有多种不同的语法。箭头函数的基本组成包括函数参数、箭头和函数体。

1、箭头函数的语法

**第一种情况:**箭头函数中只有一个参数,函数体中只有一条语句,示例代码如下:

javascript 复制代码
let count = price => price;

console.log(count(6.6));//6.6

//相当于
function count(price){
    return price;
}

**第二种情况:**箭头函数中参数多于一个,需要使用小括号将参数包含起来,示例代码如下:

javascript 复制代码
let count = (price,number) => `${price},${number}`;

console.log(count(6.6, 10));	//6.6,10

//相当于
function count(price,number){
    return price + "," + number;
}

**第三种情况:**箭头函数中没有参数,需要使用一对空的小括号,示例代码如下:

javascript 复制代码
let count = () => "商品名称:品牌相机";

console.log(count());//商品名称:品牌相机

**第四种情况:**箭头函数中函数体中有多条语句,需要使用大括号将函数体包含起来,示例代码如下:

javascript 复制代码
let count = (price,number) => {
    let total = price * number;
    return total;
};

console.log(count(6.6, 10));	//66

**第五种情况:**箭头函数中返回值是一个对象字面量,需要使用小括号将对象字面量包含起来,示例代码如下:

javascript 复制代码
let count = (price,number) => ({price:price,number:number});

console.log(count(6.6, 10));	//{price: 6.6, number: 10}

2、箭头函数中的 this

在 JavaScript 中,this 关键字的指向是可以改变的,它会根据当前上下文的变化而变化。为了解决 this 关键字指向的问题,可以使用 bind() 方法将 this 绑定到某个对象上。而在箭头函数中并没有 this 绑定,如果箭头函数包含在非箭头函数中,那么箭头函数中的 this 指向的是最近的非箭头函数中的 this,否则,this 会被设置为全局对象。示例代码如下:

javascript 复制代码
var type = "手机";
var obj = {
    type: "电脑",
    show: function(){
        setTimeout(() => console.log(this.type), 3000);
    }
}
obj.show();      //电脑

上述代码中,在调用 setTimeout() 方法时使用了箭头函数,箭头函数中的 this 和 show() 方法中的 this 一致,而这个 this 指向的是 obj 对象,所以在调用 obj 对象的 show() 方法时显示的结果是"电脑"。

相关推荐
2301_7683502313 分钟前
Vue第二期:组件及组件化和组件的生命周期
前端·javascript·vue.js
华洛2 小时前
公开一个AI产品的商业逻辑与设计方案——AI带来的涂色卡自由
前端·后端·产品
明远湖之鱼2 小时前
opentype.js 使用与文字渲染
前端·svg·字体
90后的晨仔2 小时前
Vue 3 组合式函数(Composables)全面解析:从原理到实战
前端·vue.js
今天头发还在吗2 小时前
【React】动态SVG连接线实现:图片与按钮的可视化映射
前端·javascript·react.js·typescript·前端框架
小刘不知道叫啥2 小时前
React 源码揭秘 | suspense 和 unwind流程
前端·javascript·react.js
szial2 小时前
为什么 React 推荐 “不可变更新”:深入理解 React 的核心设计理念
前端·react.js·前端框架
mapbar_front3 小时前
面试是一门学问
前端·面试
90后的晨仔3 小时前
Vue 3 中 Provide / Inject 在异步时不起作用原因分析(二)?
前端·vue.js
90后的晨仔3 小时前
Vue 3 中 Provide / Inject 在异步时不起作用原因分析(一)?
前端·vue.js