JavaScript

JavaScript

Tutorial JavaScript: Funciones flecha

JavaScript funciones flecha: definición y uso. Domina la definición y uso de funciones flecha en JavaScript con ejemplos prácticos.

Las funciones flecha en JavaScript, también conocidas como "arrow functions", son una forma más concisa y elegante de definir funciones en el lenguaje. Introducidas en la versión de ECMAScript 2015 (ES6), las funciones flecha ofrecen una sintaxis más corta en comparación con las funciones regulares y ofrecen otras ventajas, como el uso de un léxico this.

En términos de sintaxis, las funciones flecha pueden ser reconocidas por su característica flecha =>. A continuación, se presenta una comparación entre una función regular y una función flecha:

Función regular:

function sumar(a, b) {
  return a + b;
}

Función flecha:

const sumar = (a, b) => {
  return a + b;
};

Como se observa, en lugar de utilizar la palabra clave function, se utiliza una flecha => entre los parámetros y el cuerpo de la función.

Las funciones flecha pueden ser utilizadas en diferentes situaciones, como en el caso de las funciones anónimas que son pasadas como argumentos a otras funciones. Por ejemplo, al utilizar la función map() para transformar un array:

Función regular:

const numeros = [1, 2, 3, 4];
const cuadrados = numeros.map(function (numero) {
  return numero * numero;
});

Función flecha:

const numeros = [1, 2, 3, 4];
const cuadrados = numeros.map(numero => {
  return numero * numero;
});

Sintaxis más concisa

Para funciones que solo retornan un valor sin incluir instrucciones adicionales, las funciones flecha ofrecen una sintaxis más corta utilizando una expresión implícita:

const sumar = (a, b) => a + b;

const numeros = [1, 2, 3, 4];
const cuadrados = numeros.map(numero => numero * numero); // [1, 4, 9, 16]

En estos ejemplos, se omite el uso de las llaves {} y la palabra clave return. El resultado de la expresión es retornado automáticamente.

En JavaScript, es posible omitir los paréntesis al definir una función flecha que tenga un único argumento. Esta característica permite simplificar aún más la sintaxis de las funciones flecha, especialmente cuando se utilizan para funciones breves o anónimas. Sin embargo, si la función flecha requiere más de un argumento, es necesario incluir los paréntesis para delimitarlos.

const cuadrado = x => x * x;
// Equivalente a:
// const cuadrado = (x) => x * x;

const numeros = [1, 2, 4];
const cuadrados = numeros.map(x => x * x); // [1, 4, 16]

this propio

Otra ventaja importante de las funciones flecha es que no tienen su propio this, es decir, el valor de this dentro de una función flecha es el mismo que el de la función que la contiene. Esto puede ser útil en situaciones donde se desea que this se refiera al contexto externo a la función y no al contexto de la propia función.

Por ejemplo, en un objeto que tiene un método para mostrar información utilizando la función setTimeout:

Función regular:

const objeto = {
  nombre: 'Objeto',
  mostrarNombre: function () {
    setTimeout(function () {
      console.log(this.nombre); // Esto no funcionará correctamente
    }, 1000);
  }
};

En este caso, el valor de this dentro de la función pasada a setTimeout es diferente al this del método mostrarNombre. Para solucionar este problema, en las versiones anteriores de JavaScript se utilizaba una variable adicional para almacenar el valor de this:

Función regular con solución al problema de this:

const objeto = {
  nombre: 'Objeto',
  mostrarNombre: function () {
    const self = this;
    setTimeout(function () {
      console.log(self.nombre); // Esto funcionará correctamente
    }, 1000);
  }
};

Función flecha para solucionar el problema de this:

const objeto = {
  nombre: 'Objeto',
  mostrarNombre: function () {
    setTimeout(() => {
      console.log(this.nombre); // Esto funcionará correctamente
    }, 1000);
  }
};

En resumen, las funciones flecha en JavaScript son una adición útil al lenguaje que ofrecen una sintaxis más concisa y fácil de escribir, y facilitan el manejo del contexto de this. Esto las hace ideales para su uso en funciones anónimas y breves que requieran de un contexto específico.

Certifícate en JavaScript con CertiDevs PLUS

Ejercicios de esta lección Funciones flecha

Evalúa tus conocimientos de esta lección Funciones flecha con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.

Funciones flecha

JavaScript
Puzzle

Polimorfismo

JavaScript
Test

Array

JavaScript
Código

Transformación con map()

JavaScript
Test

Introducción a JavaScript

JavaScript
Test

Gestor de tareas con JavaScript

JavaScript
Proyecto

Manipulación DOM

JavaScript
Test

Funciones

JavaScript
Test

Funciones flecha

JavaScript
Código

Async / Await

JavaScript
Código

Creación y uso de variables

JavaScript
Test

Excepciones

JavaScript
Puzzle

Promises

JavaScript
Código

Funciones cierre (closure)

JavaScript
Test

Herencia

JavaScript
Puzzle

Herencia

JavaScript
Test

Estructuras de control

JavaScript
Código

Selección de elementos DOM

JavaScript
Test

Modificación de elementos DOM

JavaScript
Test

Filtrado con filter() y find()

JavaScript
Test

Funciones cierre (closure)

JavaScript
Puzzle

Funciones

JavaScript
Puzzle

Mapas con Map

JavaScript
Test

Reducción con reduce()

JavaScript
Test

Callbacks

JavaScript
Puzzle

Manipulación DOM

JavaScript
Puzzle

Promises

JavaScript
Test

Async / Await

JavaScript
Test

Eventos del DOM

JavaScript
Puzzle

Async / Await

JavaScript
Puzzle

Promises

JavaScript
Puzzle

Filtrado con filter() y find()

JavaScript
Código

Callbacks

JavaScript
Test

Creación de clases y objetos Restaurante

JavaScript
Código

Reducción con reduce()

JavaScript
Código

Filtrado con filter() y find()

JavaScript
Puzzle

Reducción con reduce()

JavaScript
Puzzle

Conjuntos con Set

JavaScript
Puzzle

Herencia de clases

JavaScript
Código

Eventos del DOM

JavaScript
Test

Clases y objetos

JavaScript
Puzzle

Modificación de elementos DOM

JavaScript
Puzzle

Mapas con Map

JavaScript
Puzzle

Funciones

JavaScript
Código

Tipos de datos

JavaScript
Test

Clases y objetos

JavaScript
Test

Array

JavaScript
Test

Conjuntos con Set

JavaScript
Test

Array

JavaScript
Puzzle

Encapsulación

JavaScript
Puzzle

Clases y objetos

JavaScript
Código

Uso de operadores

JavaScript
Puzzle

Uso de operadores

JavaScript
Test

Estructuras de control

JavaScript
Test

Excepciones

JavaScript
Test

Transformación con map()

JavaScript
Puzzle

Funciones flecha

JavaScript
Test

Selección de elementos DOM

JavaScript
Puzzle

Encapsulación

JavaScript
Test

Mapas con Map

JavaScript
Código

Creación y uso de variables

JavaScript
Puzzle

Polimorfismo

JavaScript
Puzzle

Tipos de datos

JavaScript
Puzzle

Estructuras de control

JavaScript
Puzzle

Todas las lecciones de JavaScript

Accede a todas las lecciones de JavaScript y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.

Certificados de superación de JavaScript

Supera todos los ejercicios de programación del curso de JavaScript y obtén certificados de superación para mejorar tu currículum y tu empleabilidad.

En esta lección

Objetivos de aprendizaje de esta lección

  1. Comprender qué son las funciones flecha y cómo se definen.
  2. Conocer las ventajas y usos de las funciones flecha en comparación con las funciones regulares.
  3. Aprender a utilizar las funciones flecha en diversas situaciones, incluyendo funciones anónimas y funciones con un solo valor de retorno.
  4. Entender el concepto de léxico this y cómo las funciones flecha simplifican su manejo en comparación con las funciones regulares.