TypeScript
Tutorial TypeScript: Inmutabilidad
TypeScript inmutabilidad: técnicas y ejemplos. Domina las técnicas de inmutabilidad en TypeScript con ejemplos prácticos y detallados.
Aprende TypeScript GRATIS y certifícateLa inmutabilidad es un principio fundamental en programación funcional. Un objeto inmutable es un objeto cuyo estado no puede ser modificado después de que se ha creado.
Concepto de inmutabilidad
Imagínese que se tiene un objeto en código, y varias partes del programa pueden acceder y cambiar este objeto. En tal escenario, es complicado seguir la lógica del programa y predecir su comportamiento, porque el estado del objeto puede cambiar en cualquier momento desde cualquier lugar. Aquí es donde entra en juego el principio de inmutabilidad.
Cuando se trabaja con objetos inmutables, el objeto no se modifica. En su lugar, si se necesita hacer cambios, se puede crear una copia del objeto con los cambios aplicados. Esto facilita el rastreo del estado de los objetos y reduce el riesgo de efectos secundarios inesperados.
Estructuras de datos inmutables
En TypeScript, los tipos primitivos son inmutables por defecto. Estos incluyen boolean
, number
, string
, null
, undefined
y symbol
.
let a = "hola";
a = "adios"; // Esto no modifica la cadena original, sino que reasigna a a una nueva cadena
Sin embargo, los tipos de datos complejos, como los objetos y los arrays, no son inmutables.
let a = { saludo: "hola" };
a.saludo = "adios"; // Esto modifica el objeto original
Si se quiere hacer que estos tipos sean inmutables, se deben utilizar técnicas especiales.
Objetos inmutables
Se puede hacer que un objeto sea inmutable utilizando Object.freeze
.
let a = { saludo: "hola" };
Object.freeze(a);
a.saludo = "adios"; // Esto lanza un error
Se debe tener en cuenta que Object.freeze
solo es superficial, lo que significa que no hace que los objetos anidados sean inmutables.
let a = { saludo: { palabra: "hola" } };
Object.freeze(a);
a.saludo.palabra = "adios"; // Esto no lanza un error
En el ejemplo anterior, se ha hecho Object.freeze
de a
, pero no de a.saludo
, de forma que no se podría modificar el primero pero sí el segundo.
Arrays inmutables
Pueden tratarse a los arrays como inmutables utilizando métodos que no modifican el array original, sino que devuelven un nuevo array con los cambios aplicados. Estos métodos incluyen map
, filter
, slice
, concat
, etc. Por ejemplo, el método map
devuelve un nuevo array al que se le aplica una transformación, pero sin modificar el array original.
let a = [1, 2, 3];
let b = a.map(x => x * 2);
// b es [2, 4, 6], a todavía es [1, 2, 3]
Readonly en TypeScript
TypeScript proporciona una manera de asegurar que una variable no se modifique: el modificador readonly
.
interface Persona {
readonly nombre: string;
readonly edad: number;
}
let persona: Persona = { nombre: "Juan", edad: 30 };
persona.nombre = "Pedro"; // Esto arroja un error
En este ejemplo, nombre
y edad
son solo de lectura, por lo que no pueden ser modificados después de la asignación inicial.
En resumen, la inmutabilidad es un principio poderoso que puede hacer que el código sea más predecible y más fácil de entender. En TypeScript, se pueden usar varias técnicas para asegurar la inmutabilidad, incluyendo Object.freeze
, métodos inmutables de arrays y el modificador readonly
.
Ejercicios de esta lección Inmutabilidad
Evalúa tus conocimientos de esta lección Inmutabilidad con nuestros retos de programación de tipo Test, Puzzle, Código y Proyecto con VSCode, guiados por IA.
Funciones
Funciones de primera clase
Tipos de utilidad
Clases
OOP y CRUD en TypeScript
Tipos literales
Namespaces
Módulos
Funciones TypeScript
Encapsulación
Interfaces
Funciones puras
Variables y constantes
Funciones flecha
Funciones puras
Control de flujo
Resolución de módulos
Control de flujo
Polimorfismo
Operadores
Funciones flecha
Herencia
Clases y objetos
Clases
Operadores
Encapsulación
Herencia
Funciones
Tipos de unión e intersección
Funciones de alto orden
Inmutabilidad
Interfaces
Funciones de alto orden
Tipos de unión e intersección
Tipos genéricos
Control de flujo
Polimorfismo
Interfaces
Tipos literales
Tipos de utilidad
Tipos genéricos
Inmutabilidad
Herencia de clases
Variables y constantes
Variables y constantes
Funciones de primera clase
Introducción a TypeScript
Todas las lecciones de TypeScript
Accede a todas las lecciones de TypeScript y aprende con ejemplos prácticos de código y ejercicios de programación con IDE web sin instalar nada.
Introducción A Typescript
Introducción Y Entorno
Variables Y Constantes
Sintaxis
Operadores
Sintaxis
Control De Flujo
Sintaxis
Funciones
Sintaxis
Funciones Flecha
Sintaxis
Clases Y Objetos
Programación Orientada A Objetos
Interfaces
Programación Orientada A Objetos
Encapsulación
Programación Orientada A Objetos
Herencia
Programación Orientada A Objetos
Polimorfismo
Programación Orientada A Objetos
Inmutabilidad
Programación Funcional
Funciones Puras
Programación Funcional
Funciones De Primera Clase
Programación Funcional
Funciones De Alto Orden
Programación Funcional
Tipos Literales
Tipos De Datos Avanzados
Tipos Genéricos
Tipos De Datos Avanzados
Tipos De Unión E Intersección
Tipos De Datos Avanzados
Tipos De Utilidad
Tipos De Datos Avanzados
Módulos
Namespaces Y Módulos
Namespaces
Namespaces Y Módulos
Resolución De Módulos
Namespaces Y Módulos
Certificados de superación de TypeScript
Supera todos los ejercicios de programación del curso de TypeScript 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
- Comprender el concepto de inmutabilidad y su importancia en programación funcional.
- Conocer las ventajas de trabajar con objetos inmutables para facilitar el rastreo del estado de los objetos y reducir los efectos secundarios inesperados.
- Aprender a hacer objetos inmutables utilizando
Object.freeze
. - Entender cómo los métodos inmutables de arrays, como
map
,filter
,slice
yconcat
, permiten trabajar con arrays sin modificar el array original. - Saber cómo utilizar el modificador
readonly
en TypeScript para asegurar que una variable no se modifique después de su asignación inicial.