JavaScript箭头函数的五种使用方法及三点注意事项

 更新时间:2022年08月09日 09:02:52   作者:猪痞恶霸  
这篇文章主要介绍了JavaScript箭头函数的五种使用方法及三点注意事项,箭头函数是ES6新增的定义函数的方式,文章围绕主题展开详细的内容介绍,需要的朋友可以参考一下

前言:

箭头函数是ES6新增的定义函数的方式,我们可以使用()=>{}来顶替以前的函数定义方式,下面从五个使用姿势与三点注意事项来刨析箭头函数。

使用

简略编写

当我们箭头函数函数只有一个参数的时候是可以将()省略,当代码块只有一行的时候可以将{}return省略

const fn = num => num.sort();
console.log(fn([2, 1, 3])); // [1,2,3]

如上代码块只有一个参数num且只有一行代码return num.sort(),所以将(){}return省略

结合解构赋值

为了进一步简化还可以与解构赋值结合使用

let person = {
  name: "猪痞恶霸",
  age: 12,
};
const fn = ({ name, age }) => name + "今年" + age + "岁了";
console.log(fn(person)); // 猪痞恶霸今年12岁了

使用解构赋值直接将nameage解构,替换了person,name的用法,使函数更加简洁。

结合扩展运算符

在函数参数定义中可以结合rest参数搭配使用

const fn = (...arr) => arr.sort();
console.log(fn(2, 1, 4)); // [1,2,4]

使用...arr将所有参数都包裹在内,在函数体内进行一些需要的操作。

this指向的改变

在箭头函数中使用this,它的指向是不变的,因为箭头函数没有拥有属于自己的this,其指向的是函数定义时所在的对象 , 所以箭头函数的出现往往就顶替了我们常用的let _that = this又或者在函数结尾使用绑定this指向的对象来解决在函数体内this的问题

var name = "fzf404";
function set() {
  setTimeout(() => {
    console.log(this.name);
  }, 1000);
}
set(); // fzf404
set.call({ name: "猪痞恶霸" }); // 猪痞恶霸

如上例子,在全局中声明了一个name变量,我们再通过call()绑定新的对象{ name: "猪痞恶霸" },在set函数执行的时候,箭头函数被定义,而被定义的时候其已经通过set.call()更改了指向的对象,所以打印出的是新的对象中的name属性,这就是箭头函数的this指向特点,如果是普通函数,其指向依旧是顶层对象。

绑定this

在之前ES5可以通过bindcallapply来显式绑定this对象,而箭头函数的出现打破了这种局面,同时也配套使用::来作为函数绑定的方式

::的使用方法:将要绑定的对象放在::的左边,函数放在::的右边,执行后,函数内的this就会指向绑定的对象

obj::fn
// 等同于
fn.bind(obj)

如上,原来的显式绑定方式与使用::的绑定方式进行一个比较,看过二者的比较就可以了解::的使用了。

注意细节

关于构造

箭头函数无法作为一个构造函数,所以无法通过new命令来构造

const fn = () => {}
let _fn = new fn() // fn is not a constructor

如上,如果使用new来构造的化就会抛出fn不是一个构造函数

关于参数对象

在箭头函数内是无法使用arguments即参数对象,因为在其函数体内部不存在arguments对象当然我们可以使用扩展运算符来代替其使用,比使用参数对象方便。

const fn = () => {
    console.log(arguments)
}
fn() // arguments is not defined

关于yield命令

箭头函数无法使用yield命令,也就是说无法将箭头函数转变为生成器函数,具体是为什么,我的直观感受就是作为生成器必须是function*,而箭头函数的形式无法作为一个生成器。

了解到这里,下面我们来看一道经典的面试题。

面试题

let name = "猪痞恶霸";
let person = {
    name:"fzf404",
    fn: () => {
        setTimeout(() => {
            console.log(this.name);
        })
    }
}
person.fn();

上面是一道考察箭头函数this指向作用域的面试题,它的打印结果为undefined,我们来一点一点分析

  • 使用let在下声明了一个name
  • 再声明一个对象,内含一个name属性和一个方法,该方法使用定时器并打印this.name
  • 调用对象的这个方法,this开始寻找
  • 定时器中的箭头函数没有this,向上寻找,到达person,由于person是一个对象,所以它的{}包裹的不是作用域
  • 继续向上寻找,到达了顶层对象window
  • 查看window内是否含有name属性,由于使用let声明,所以其属性不在window中,打印出undefined

到此这篇关于JavaScript箭头函数的五种使用方法及三点注意事项的文章就介绍到这了,更多相关JS箭头函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Javascript运行机制之Event Loop

    Javascript运行机制之Event Loop

    这篇文章主要介绍了Javascript运行机制之Event Loop,在学习Event Loop前,首先需要了解的几个概念Javascript是单线程、任务队列、同步任务、异步任务、Javascript执行栈,下面来看看文章的详细介绍吧
    2021-12-12
  • 微信小程序使用车牌号输入法的示例代码

    微信小程序使用车牌号输入法的示例代码

    这篇文章主要介绍了微信小程序使用车牌号输入法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-08-08
  • javascript中caller和callee详解

    javascript中caller和callee详解

    有些小伙伴可能会问caller,callee 是什么?在javascript 中有什么样的作用?那么本篇会对于此做一些基本介绍。希望能够对大家理解javascript中的callee与caller有所帮助。
    2015-08-08
  • 小程序自定义弹出框效果

    小程序自定义弹出框效果

    这篇文章主要为大家详细介绍了小程序自定义弹出框效果,支持淡入淡出动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • JavaScript原型链示例分享

    JavaScript原型链示例分享

    这篇文章主要介绍了JavaScript原型链示例,有需要的朋友可以参考一下
    2014-01-01
  • layui实现数据表格table分页功能(ajax异步)

    layui实现数据表格table分页功能(ajax异步)

    这篇文章主要为大家详细介绍了layui实现数据表格table分页功能、异步加载,表格渲染,含条件查询,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • javascript数组的一些常用方法详细汇总

    javascript数组的一些常用方法详细汇总

    在JavaScript开发中,数组的操作至关重要,本文详细介绍了数组的常用方法,包括添加、删除、查找、迭代、遍历、排序和变换等功能,掌握这些方法,可以有效地处理和操作数组数据,提高开发效率和代码的可维护性,需要的朋友可以参考下
    2024-09-09
  • JavaScript实现模块拖拽功能的代码示例

    JavaScript实现模块拖拽功能的代码示例

    这篇文章将给大家详细介绍一下JavaScript实现模块的拖拽功能的代码示例,文中有详细的实现步骤,需要的朋友可以参考下
    2023-07-07
  • D3.js实现拓扑图的示例代码

    D3.js实现拓扑图的示例代码

    本篇文章主要介绍了D3.js实现拓扑图的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • JS运算符简单用法示例

    JS运算符简单用法示例

    这篇文章主要介绍了JS运算符简单用法,结合实例形式详细分析了JavaScript各种逻辑运算符、数学运算符、关系运算符等相关操作技巧,需要的朋友可以参考下
    2020-01-01

最新评论