Typescript高级: 深入理解const和readonly

2024-05-09 12:20

本文主要是介绍Typescript高级: 深入理解const和readonly,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

  • 在编程语言中,const 和 readonly 是两种用于声明常量或只读属性的关键字
  • 它们帮助开发者确保数据的不可变性,从而提高代码的安全性和可维护性
  • 虽然这两个概念在不同的编程语言中可能有所差异
  • 但本文将以 TypeScript 为例,深入探讨 const 和 readonly 的使用场景

const 关键字

  • 在 TypeScript(以及JavaScript ES6之后的版本)中
  • const 关键字用于声明一个常量变量,其值在初始化后不能被重新赋值
  • 这意味着一旦给 const 变量赋予了一个初始值,这个值就不能改变
  • 例如,const pi = 3.14; 声明了一个名为 pi 的常量,尝试修改 pi 的值会引发编译错误
  • 一般示例
const arr = [10, 30, 40, "abc"];
// arr = [100, 30, 40, "abc"]; // 错误:不能给常量赋新值const arr2 = [10, 30, 40, "abc"] as const; // 使用 as const 使数组元素变为 readonly
// arr2[0] = 100; // 错误:无法修改只读元素
  • 需要注意的是,对于数组或对象这样的复杂数据类型
  • const 只保证引用不变,数组或对象内部的元素仍然可以被修改
  • 除非这些元素本身也是通过 const 或 readonly 声明的
  • 对于对象和数组,const 保证的是引用的不可变,而非内部结构的冻结
  • 使用 Object.freeze() 可以进一步使对象完全不可变
    const frozenObj = Object.freeze({ key: 'value' }); // 对象及其属性均不可变
    
  • 解构赋值与const:利用解构赋值,可以从 const 数组或对象中提取值
  • 即使原始数据不可变,仍能灵活操作提取出的数据
    const [a, b] = [10, 20] as const; // a 和 b 都是常量
    

readonly 关键字

  • readonly 是 TypeScript 提供的一个修饰符,用于标记类的属性或接口的成员为只读

  • 与 const 不同,它不仅适用于基本类型,还能确保数组或对象的结构不会被改变

  • 即不能添加、删除或修改元素(对于对象,则是不能修改其属性值)

    interface ReadonlyArray<T> {readonly [index: number]: T;
    }
    function showArr(arr: readonly any[]) {// arr[0] = 100; // 错误:试图修改只读数组元素console.log(arr);
    }
  • TypeScript 引入了 readonly 关键字,它主要用于类的属性和接口成员

  • 以声明这些属性或成员只能被读取,而不能被赋值或修改

  • 这对于设计具有不变性特性的类和接口非常有用,尤其是在构建复杂的数据模型时

    class Person {public name: string;readonly birthDate: Date;constructor(name: string, birthDate: Date) {this.name = name;this.birthDate = birthDate;}
    }
    
  • 泛型与readonly:结合泛型,可以创建通用的只读集合类型,增加代码的复用性和类型安全性

    function createReadOnlyArray<T>(items: T[]): readonly T[] {return Object.freeze(items);
    }
    

const 与 readonly 的区别

1 ) 作用域不同

  • const 主要用于变量声明
  • 而 readonly 用于类的属性或接口的定义中,提供更细粒度的控制。

2 ) 修改限制

  • const 确保变量引用不可变,但不阻止数组或对象内容的修改(除非使用 as const 转换)
  • readonly 则直接限制了数组或对象结构的任何变更。

3 ) 应用场景

  • const 适合于那些一旦赋值就不应更改的基本类型或复杂类型的引用
  • readonly 则在设计类和接口时,用来定义那些对外只暴露读取接口
  • 内部可以修改(通过构造函数或方法)的属性

总结

  • const 和 readonly 作为不变性编程的核心概念
  • 在保证代码质量、减少bug、优化性能等方面发挥着重要作用
  • 它们鼓励开发者采用更安全、更易于推理的编程模式,尤其是在团队协作和长期维护的项目中
  • 通过与其他语言特性的结合使用,如泛型、解构赋值等
  • 可以进一步提升代码的灵活性和表达力,构建出既强大又稳定的软件系统

这篇关于Typescript高级: 深入理解const和readonly的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973405

相关文章

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

从基础到高级详解Python数值格式化输出的完全指南

《从基础到高级详解Python数值格式化输出的完全指南》在数据分析、金融计算和科学报告领域,数值格式化是提升可读性和专业性的关键技术,本文将深入解析Python中数值格式化输出的相关方法,感兴趣的小伙... 目录引言:数值格式化的核心价值一、基础格式化方法1.1 三种核心格式化方式对比1.2 基础格式化示例

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象

深度解析Python yfinance的核心功能和高级用法

《深度解析Pythonyfinance的核心功能和高级用法》yfinance是一个功能强大且易于使用的Python库,用于从YahooFinance获取金融数据,本教程将深入探讨yfinance的核... 目录yfinance 深度解析教程 (python)1. 简介与安装1.1 什么是 yfinance?

MySQL数据类型与表操作全指南( 从基础到高级实践)

《MySQL数据类型与表操作全指南(从基础到高级实践)》本文详解MySQL数据类型分类(数值、日期/时间、字符串)及表操作(创建、修改、维护),涵盖优化技巧如数据类型选择、备份、分区,强调规范设计与... 目录mysql数据类型详解数值类型日期时间类型字符串类型表操作全解析创建表修改表结构添加列修改列删除列

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.

深入解析Java NIO在高并发场景下的性能优化实践指南

《深入解析JavaNIO在高并发场景下的性能优化实践指南》随着互联网业务不断演进,对高并发、低延时网络服务的需求日益增长,本文将深入解析JavaNIO在高并发场景下的性能优化方法,希望对大家有所帮助... 目录简介一、技术背景与应用场景二、核心原理深入分析2.1 Selector多路复用2.2 Buffer

Java Stream 的 Collectors.toMap高级应用与最佳实践

《JavaStream的Collectors.toMap高级应用与最佳实践》文章讲解JavaStreamAPI中Collectors.toMap的使用,涵盖基础语法、键冲突处理、自定义Map... 目录一、基础用法回顾二、处理键冲突三、自定义 Map 实现类型四、处理 null 值五、复杂值类型转换六、处理