箭头函数与普通函数(function)的区别

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: 箭头函数是ES6引入的新语法,相比传统函数表达式更简洁,且没有自己的this、arguments、super或new.target绑定,而是继承自外层作用域。这使得箭头函数在处理回调和闭包时更加灵活方便。
  1. 语法形式

    • 普通函数
      • 有函数声明和函数表达式两种形式。函数声明的语法是function functionName(parameters) {... },例如:
        function add(a, b) {
                 
          return a + b;
        }
        
      • 函数表达式是将函数赋值给一个变量,如let add = function(a, b) { return a + b; };
    • 箭头函数
      • 语法更加简洁,它的基本形式是(parameters) => {... }。如果只有一个参数,括号可以省略,例如a => { return a * 2; };如果函数体只有一条语句且是返回值,花括号和return关键字都可以省略,像a => a * 2
  2. this指向

    • 普通函数
      • this的值在函数被调用时确定,它取决于函数的调用方式。在全局作用域中调用函数,this指向全局对象(在浏览器环境中是window,在Node.js环境中是global)。例如:
        let obj = {
                 
          name: 'John',
          sayName: function() {
                 
            console.log(this.name);
          }
        };
        obj.sayName();// 'John',这里this指向obj
        let sayNameFn = obj.sayName;
        sayNameFn();// undefined,这里this指向全局对象(如果没有name属性就为undefined)
        
    • 箭头函数
      • 没有自己的this,它的this是继承自外层作用域的this。例如:
        let obj = {
                 
          name: 'John',
          sayName: () => {
                 
            console.log(this.name);
          }
        };
        obj.sayName();// 这里this指向外层作用域的this,可能不是obj
        
  3. arguments对象
    • 普通函数
      • 有自己的arguments对象,它是一个类数组对象,包含了函数被调用时传入的所有参数。例如:
        function sum() {
                 
          let result = 0;
          for (let i = 0; i < arguments.length; i++) {
                 
            result += arguments[i];
          }
          return result;
        }
        console.log(sum(1, 2, 3));// 6
        
    • 箭头函数
      • 没有自己的arguments对象。如果需要访问参数,可以使用剩余参数(...)语法。例如:
        let sum = (...args) => {
                 
          let result = 0;
          for (let i = 0; i < args.length; i++) {
                 
            result += args[i];
          }
          return result;
        };
        console.log(sum(1, 2, 3));// 6
        
  4. 构造函数
    • 普通函数
      • 可以作为构造函数使用,通过new关键字来创建对象实例。构造函数内部会创建一个新的对象(this),并将其原型指向函数的prototype属性。例如:
        function Person(name) {
                 
          this.name = name;
        }
        let john = new Person('John');
        console.log(john.name);// 'John'
        
    • 箭头函数
      • 不能作为构造函数使用,因为它没有自己的this,也没有prototype属性。如果尝试使用new关键字调用箭头函数,会抛出错误。例如:
        let Person = (name) => {
                 
          this.name = name;
        };
        let john = new Person('John');// 报错
        
  5. 适用场景
    • 普通函数
      • 适用于需要动态绑定this的场景,如对象的方法,构造函数等。当需要使用arguments对象或者需要通过new关键字创建对象实例时,也必须使用普通函数。
    • 箭头函数
      • 适用于简洁的函数表达式,特别是在不需要自己的thisarguments对象的场景。例如,在数组的mapfilterreduce等方法中作为回调函数使用,可以使代码更加简洁清晰。如let numbers = [1, 2, 3]; let doubled = numbers.map(num => num * 2);
相关文章
|
26天前
|
中间件 Docker Python
【Azure Function】FTP上传了Python Function文件后,无法在门户页面加载函数的问题
通过FTP上传Python Function至Azure云后,出现函数列表无法加载的问题。经排查,发现是由于`requirements.txt`中的依赖包未被正确安装。解决方法为:在本地安装依赖包到`.python_packages/lib/site-packages`目录,再将该目录内容上传至云上的`wwwroot`目录,并重启应用。最终成功加载函数列表。
|
2月前
|
JavaScript
箭头函数与普通函数(function)的区别
箭头函数是ES6引入的新特性,与传统函数相比,它有更简洁的语法,且没有自己的this、arguments、super或new.target绑定,而是继承自外层作用域。箭头函数不适用于构造函数,不能使用new关键字调用。
|
2月前
|
数据可视化 开发者 索引
详解Wireshark LUA插件函数:function p_myproto.dissector(buffer, pinfo, tree)
在 Wireshark 中,LUA 插件通过 `function p_myproto.dissector(buffer, pinfo, tree)` 扩展协议解析能力,解析自定义应用层协议。参数 `buffer` 是 `PacketBuffer` 类型,表示原始数据包内容;`pinfo` 是 `ProtoInfo` 类型,包含数据包元信息(如 IP 地址、协议类型等);`tree` 是
84 1
|
2月前
|
C++ 容器
函数对象包装器function和bind机制
函数对象包装器function和bind机制
21 0
|
4月前
【Azure Durable Function】PowerShell Activity 函数遇见 Newtonsoft.Json.JsonReaderException: The reader's MaxDepth of 64 has been exceeded.
【Azure Durable Function】PowerShell Activity 函数遇见 Newtonsoft.Json.JsonReaderException: The reader's MaxDepth of 64 has been exceeded.
|
4月前
|
安全 JavaScript 应用服务中间件
【Azure Function App】如何修改Azure函数应用的默认页面呢?
【Azure Function App】如何修改Azure函数应用的默认页面呢?
|
4月前
|
C# C++ Python
【Azure 应用服务】Azure Durable Function(持久函数)在执行Activity Function时候,因为调用函数名称错误而导致长时间无响应问题
【Azure 应用服务】Azure Durable Function(持久函数)在执行Activity Function时候,因为调用函数名称错误而导致长时间无响应问题
|
5月前
|
C++ 运维
开发与运维函数问题之使用std::function实现回调函数的示例如何解决
开发与运维函数问题之使用std::function实现回调函数的示例如何解决
41 7
|
4月前
|
SQL JavaScript 前端开发
【Azure 应用服务】Azure JS Function 异步方法中执行SQL查询后,Callback函数中日志无法输出问题
【Azure 应用服务】Azure JS Function 异步方法中执行SQL查询后,Callback函数中日志无法输出问题
|
4月前
|
JSON 数据格式 Python
【Azure 应用服务】Azure Function Python函数中,如何获取Event Hub Trigger的消息Event所属于的PartitionID呢?
【Azure 应用服务】Azure Function Python函数中,如何获取Event Hub Trigger的消息Event所属于的PartitionID呢?