登录
首页 >  文章 >  前端

干净的代码:JavaScript 不变性、核心概念和工具

时间:2025-01-19 20:36:55 438浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《干净的代码:JavaScript 不变性、核心概念和工具》,这篇文章主要讲到等等知识,如果你对文章相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

干净的代码:JavaScript 不变性、核心概念和工具

什么是数据可变性?

直接修改现有数据值的行为称为可变性。在 JavaScript 中,对象和数组默认是可变的:

// 商品和购物车的不可变类型
type Product = {
  readonly id: number;
  readonly name: string;
  readonly price: number;
};

type Cart = {
  readonly items: ReadonlyArray;
  readonly total: number;
};

// TypeScript 防止修改
const cart: Cart = {
  items: [],
  total: 0
};

// 编译错误:items 是只读的
cart.items.push({ id: 1, name: "Laptop", price: 999 });

// 函数必须创建一个新的购物车
function addProduct(cart: Cart, product: Product): Cart {
  return {
    items: [...cart.items, product],
    total: cart.total + product.price
  };
}

// TypeScript 保证原对象不会被更改
const newCart = addProduct(cart, { id: 1, name: "Laptop", price: 999 });

TypeScript 的只读修饰符:

  • readonly:防止属性更改。
  • ReadonlyArray:防止数组更改。
  • Readonly:使所有属性都只读。

这些类型会在编译时进行检查,有助于尽早发现错误。

结论

不可变性使您的代码更可预测且更易于维护。虽然需要一些时间来适应,但可靠性和可维护性方面的好处是值得的。

今天关于《干净的代码:JavaScript 不变性、核心概念和工具》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>