NGRX 的信号存储 – 主要概念细分

ngrx 的信号存储 - 主要概念细分

特征

基于信号函数式和声明式用于本地或全局状态管理可通过自定义功能进行扩展

与 ngrx 全球商店相比如何?

更轻量级和简化的api不必太担心数据流似乎更难误用,比如重用动作更容易扩展

ngrx signal store 的创建者,marko stanimirovic 在这里描述了 ngrx signalstore:深入了解 angular 中基于信号的状态管理

基于类的状态管理限制:

类型:不可能定义强类型的动态类属性或方法tree-shaking:未使用的类方法不会从最终包中删除扩展性:不支持多重继承。模块化:可以将选择器、更新器和效果拆分为不同的类,但不提供开箱即用的

让我们通过代码示例来探索商店的 api。我们将使用一个包含产品列表和过滤功能的项目。

创建一个signalstore

signalstore 函数返回一个适合注入并在需要使用的地方提供的可注入服务。

import { signalstore } from "@ngrx/signals";export const productstore = signalstore( … );

提供状态withstate

与迄今为止的任何 ngrx store 一样,可以使用函数 withstate 来提供初始状态,该函数接受对象文字、记录或工厂函数(用于创建动态初始状态)作为输入。

Bolt.new Bolt.new

Bolt.new是一个免费的AI全栈开发工具

Bolt.new 466 查看详情 Bolt.new

import { signalstore, withstate } from "@ngrx/signals";const initialproductstate: productstate = { products: [] };export const productstore = signalstore( withstate(initialproductstate););

计算状态withcompated

构建在计算函数之上,从存储创建派生状态(计算状态)

import { signalstore, withcomputed, withstate } from "@ngrx/signals";export const productstore = signalstore( withstate(initialproductstate), withcomputed(({products}) => ({   averageprice: computed(() => {     const total = products().reduce((acc, p) => acc + p.price, 0);     return total / products().length;   }) })),

使用方法执行操作

这是定义商店运营的地方这些可以是更新存储或根据其当前状态执行某些操作的方法

import { signalstore, withcomputed, withstate, withmethods } from "@ngrx/signals";export const productstore = signalstore( withstate(initialproductstate), withcomputed(({products}) => ({   averageprice: computed(() => {     const total = products().reduce((acc, p) => acc + p.price, 0);     return total / products().length;   }) })), // crud operations withmethods((store,   productservice = inject(productservice), ) => ({   loadproducts: () => {     const products = tosignal(productservice.loadproducts())     patchstate(store, { products: products() })   },   addproduct: (product: product) => {     patchstate(store, { products: [...store.products(), product] });   },   // ... })),

withmethods & withcompulated 获取工厂函数并返回可以使用存储访问的方法和计算信号的字典。它们还在注入上下文中运行,这使得可以将依赖项注入到它们中。

用 hooks 挂钩

store的生命周期方法,目前有oninitondestroy方法

import { withhooks } from "@ngrx/signals"; export const productstore = signalstore( withhooks((store) => ({   oninit() {     // load products when the store is initialized     store.loadproducts();   }, })),);

使用实体

管理集合

当必须管理“产品、用户、客户等”等数据时使用它,其中该功能需要 crud 操作它提供了一组 api 来管理集合,例如:addentitysetentityremoteentity

export const productstorewithentities = signalstore( withentities(), // crud operations withmethods((store,   productservice = inject(productservice), ) => ({   loadproducts: () => {     const products = tosignal(productservice.loadproducts())();     patchstate(store, setallentities(products || []));   },   updateproduct: (product: product) => {     productservice.updateproduct(product);     patchstate(store, setentity(product));   }, })),

可以添加以“with”开头的多个功能,但它们只能访问之前定义的功能。

使用

signalstorefeature 创建自定义功能

signalstorefeature – 用于扩展商店的功能。

对于大型企业应用程序来说,商店可能会变得复杂且难以管理。在为项目编写功能和组件时,拆分得越好、越细,就越容易管理、维护代码和为其编写测试。

但是,考虑到 signalstore 提供的 api,除非相应地拆分代码,否则存储可能会变得难以管理。 signalstorefeature 适合将功能(或组件)的特定功能提取到独立的可测试函数中,该函数可能(并且理想情况下)可以在其他商店中重用。

export const productstore = signalstore( // previous defined state and methods // externalizing filtering options withfilteringoptions(),);export function withfilteringoptions() { return signalstorefeature(  // filtering operations withmethods(() => ({   getproductsbetweenpricerange: (lowprice: number, highprice: number, products: array, ) => {     return products.filter(p => p.price >= lowprice && p.price <= highprice);   },   getproductsbycategory: (category: string, products: array) => {     return products.filter(p => p.category === category);   }, })), );}

现在是

signalstorefeature 的示例,它展示了跨多个商店重用 signalstorefeature 的可能性。

从“@ngrx/signals”导入{ patchstate, signalstorefeature, withmethods };

export function withCrudOperations() { return signalStoreFeature(   withMethods((store) => ({     load: (crudService: CrudOperations) => crudService.load(),     update: (crudableObject: CRUD, crudService: CrudOperations) => {       crudService.update(crudableObject);       patchState(store, setEntity(crudableObject));     },   }), ));}export interface CrudOperations { load(): void; update(crudableObject: CRUD): void;}// Product & Customer services must extend the same interface.export class ProductService implements CrudOperations { load(): void {   console.log('load products'); } update(): void {   console.log('update products'); }}export class CustomerService implements CrudOperations { load(): void {   console.log('load customers'); } update(): void {   console.log('update customers'); }}// and now let’s add this feature in our storesexport const ProductStore = signalStore( withCrudOperations(),);export const CustomerStore = signalStore( withCrudOperations(),);

ngrx 工具包实用程序包

由于易于扩展,已经有一个名为 ngrx-toolkit 的实用程序包,旨在向信号存储添加有用的工具。

注入signalstore

{providedin: ‘root’} 或在组件、服务、指令等的提供者数组中

深度信号

嵌套状态属性读取为信号,按需延迟生成 补丁状态

信号api的setupdate的替代api用于更新商店的状态,只需要提供我们想要更改的值 接收方法

实用方法,有助于将 rxjs 与 signalstore 或 signalstate 一起使用

signalstate 的更轻量级替代方案

signalstate 提供了一种以简洁和简约的方式管理基于信号的状态的替代方法。 结论性想法

对于大型应用程序来说,它的可靠性还有待证明,尤其是作为全球商店应用时。

目前我认为这是对默认 signal api 的一个很好的补充,使其成为管理的一个不错的选择:

组件级状态基于特征的状态 其他资源:

https://www.stefanos-lignos.dev/posts/ngrx-signals-store

https://www.angulararchitects.io/blog/the-new-ngrx-signal-store-for-angular-2-1-flavors/(关于该主题的 4 篇文章)
https://ngrx.io/guide/signals

以上就是NGRX 的信号存储 – 主要概念细分的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/899692.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 19:38:14
下一篇 2025年11月28日 19:39:27

相关推荐

  • 比特币市值飙升,机构资金加速入场

    本文将围绕近期比特币市值的显著增长进行阐述,并深入探讨其背后一个关键的推动力——机构资金的加速入场。我们将分析宏观经济背景、市场认知变化等因素如何共同作用,促使比特币价格攀升,并讲解机构投资者进入这一市场的原因及其带来的深远影响。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Bina…

    2025年12月8日
    000
  • 比特币市值占比超50%,山寨币还有机会吗?

    当前比特币市值占比(BTC.D)稳定在50%以上,引发了市场对山寨币未来的广泛讨论。本文将深入分析比特币市值占比这一关键指标的意义,阐述判断“山寨币季节”到来的几个核心信号,并结合当前市场专家的观点,探讨山寨币在当前格局下是否仍有机会,以及其爆发周期的可能时机。 2025主流加密货币交易所官网注册地…

    2025年12月8日
    000
  • 狗币APP官网入口 狗狗币购买平台APP官网入口

    本文推荐了几个主流且可靠的狗狗币交易平台,并介绍了其特点及官网入口的查找方式。1. 币安(Binance)交易量领先,支持品种多,适合各类用户;2. OKX 产品丰富,技术先进,提供一站式交易体验;3. Coinbase 简洁合规,适合新手入门;4. Gate.io 安全性高,运营稳健。选择平台时应…

    2025年12月8日
    000
  • 免费看币行情网站 币圈行情网址有哪些

    本文将介绍几个功能强大且用户口碑良好的主流行情网站,并讲解它们各自的特点,帮助您根据自身需求,方便地获取实时价格、图表分析以及市场动态等关键信息,从而更好地进行学习和观察。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: 火币htx: 主流行…

    2025年12月8日
    000
  • u币交易所推荐

    u币交易app推荐 1. Binance Binance作为全球领先的加密货币交易平台,拥有庞大的用户群体和极高的交易量。平台支持交易的加密货币种类非常丰富,几乎涵盖了市面上主流的加密货币和众多新兴代币。提供现货交易、合约交易、期权交易等多种交易产品,满足不同投资者的需求。拥有强大的技术基础设施和多…

    2025年12月8日 好文分享
    000
  • 虚拟货币交易平台前十名排行榜

    选择一个合适的虚拟货币交易所对于加密货币投资者来说至关重要。不同的交易所提供了不同的功能、费用结构和安全措施。以下是2025年虚拟货币交易平台的前十名排行榜,帮助你找到最适合你的交易所。 1. Binance Binance 是全球领先的加密货币交易所之一,以其高交易量和多样化的交易对而闻名。Bin…

    2025年12月8日 好文分享
    000
  • 数字货币看行情交易网站入口

    在数字货币交易领域,选择一个安全且可靠的交易平台至关重要。以下是2025年数字货币交易app的排行榜,帮助你找到最适合的交易平台。 1. OKX OKX 凭借其卓越的安全性和用户友好的界面,稳居全球数字货币交易所排行榜的首位。OKX不仅支持多种数字货币交易,还提供先进的交易工具和杠杆交易选项,满足不…

    2025年12月8日 好文分享
    000
  • 炒币交易平台前十名排行榜推荐

    炒币交易平台前十名排行榜推荐 OKX: 2017 年创立,是全球排名前三的加密货币交易所,拥有强大的流动性,支持多种法币和加密货币交易,提供币币、杠杆、期权 / 交割 / 永续合约、DEX 交易、余币宝、DeFi 挖k、借贷等多元的产品矩阵,服务覆盖 200 余个国家和地区,拥有千万级用户量。 Bi…

    2025年12月8日 好文分享
    000
  • 为什么狗狗币价格在下跌?能突破0.5美元吗?狗狗币币8月价格预测

    狗狗币价格下跌的主要原因包括市场情绪低迷、名人效应减弱、缺乏应用场景及获利盘抛压。1.整体市场调整导致资金流动性下降;2.马斯克等名人的影响力边际递减;3.缺乏实际应用支撑,抗风险能力弱;4.早期投资者获利了结形成抛压。短期内突破0.5美元难度极大,需市场整体回暖叠加重大利好,长期则依赖社区共识、技…

    2025年12月8日
    000
  • 十大​炒币交易App推荐

    加密货币市场的蓬勃发展吸引了全球众多投资者的目光,而选择一个可靠、功能齐全的加密货币交易应用是参与其中的关键一步。市面上的交易平台种类繁多,各自拥有独特的优势和特点。为了帮助您更好地了解并选择适合自己的交易工具,我们整理了目前市场上用户基数较大、功能较为全面、安全性较高的十大炒币交易App。 1. …

    2025年12月8日 好文分享
    000
  • OKX 有哪些不同的订单类型?如何在 OKX 上查找我的充值地址?

    在使用数字资产交易平台okx时,了解其提供的不同订单类型以及掌握查找充值地址的方法是基础操作。本文将介绍okx上常见的几种订单类型及其作用,并详细说明如何在平台上找到您的专属充值地址。 查找 OKX 充值地址 将外部数字资产转入您的OKX账户需要获取对应的充值地址。步骤如下: 1、登录您的OKX账户…

    2025年12月8日
    000
  • 狗狗币从哪里买? 购买狗狗币的正规平台推荐

    要购买狗狗币,应选择正规、安全的数字资产交易平台。1. 币安(Binance)交易量大、资产品种丰富、手续费低,适合有经验的用户;2. OKX技术实力强、界面友好、支持Web3功能,适合各类水平用户;3. Gate.io安全性高、操作简洁,适合新手;4. KuCoin币种多样、支持自动化交易,适合喜…

    2025年12月8日 好文分享
    000
  • 2025最新虚拟货币买卖技巧与手续费对比

    本文将围绕2025年虚拟货币的买卖策略和成本控制展开。首先,文章会介绍几种在当前市场环境下依然有效的交易技巧,并通过分步讲解的方式,帮助您理解如何进行风险管理和策略制定。接着,我们会根据网络上用户的普遍反馈和讨论,对不同类型交易平台的手续费结构进行综合性对比分析,阐述其差异所在。最后,提供一些旨在降…

    2025年12月8日
    000
  • 虚拟货币是什么意思 一文读懂数字货币的概念与特点

    本文将围绕“虚拟货币是什么”这一问题展开详细说明,旨在帮助您清晰地理解数字货币的基本概念、核心技术及其主要特点。文章会首先界定虚拟货币与数字货币,然后深入讲解其背后的关键技术——区块链,并分点阐述其去中心化、加密安全等显著特征,让您对这一新兴领域有一个全面的认识。 2025主流加密货币交易所官网注册…

    2025年12月8日
    000
  • 虚拟货币的含义是什么 揭秘加密货币、代币和去中心化金融

    本文将深入探讨“虚拟货币”这一概念,并详细解答其与加密货币、代币及去中心化金融(DeFi)之间的关系。通过逐一解析这些核心术语,您将清晰地了解它们各自的定义、功能以及它们如何共同构成了当今数字金融领域的基础框架,帮助您理解这一复杂但重要的话题。 2025主流加密货币交易所官网注册地址推荐: 欧易OK…

    2025年12月8日 好文分享
    000
  • 数字货币入门指南

    本文将作为一份数字货币的入门指南,旨在帮助初学者理解其核心概念,并清晰地阐述进入这个领域需要遵循的基本步骤。通过本文的讲解,你将了解到从理论知识到实际操作的全过程,为你建立一个稳固的认知基础。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Binance币安: Gateio芝麻开门: …

    2025年12月8日
    000
  • 币圈合约最稳的平台有哪些?新手必看指南!

    币圈合约最稳的平台包括币安和欧易,它们在安全性、流动性、系统稳定性和合规性方面表现突出;其次新手选择平台需关注用户界面、教育资源、客户服务、交易成本和风险管理工具;最后规避合约风险应控制仓位、设置止损、避免情绪化交易并持续学习。 一、币圈合约最稳的平台有哪些? 在众多数字资产交易平台中,有几家凭借其…

    2025年12月8日
    000
  • 从定义到应用 轻松掌握虚拟货币金融知识

    本文将系统性地引导您走进虚拟货币的世界,从最基础的概念定义出发,逐步深入到其核心技术与实际应用场景。通过本文的阐述,您将清晰地了解虚拟货币是什么,它是如何运作的,以及它在当今金融领域中扮演的角色,从而轻松构建起对这一新兴金融领域的认知框架。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX:…

    2025年12月8日
    000
  • MASK币在哪里购买?MASK币购买平台推荐(正规)

    如何购买MASK币?可选择主流平台如币安、OKX、Coinbase、KuCoin或Gate.io。1. 币安以高流动性及丰富交易对适合各类用户;2. OKX操作友好且安全记录良好;3. Coinbase合规性强适合新手;4. KuCoin提供多样币种及活跃社区;5. Gate.io支持新项目且功能全…

    2025年12月8日 好文分享
    000
  • 以太坊浏览器地址 以太坊官网入口

    以太坊的官方信息和链上数据查询工具主要包括官方网站和区块浏览器。1. 官方网站ethereum.org提供技术文档、发展动态和生态系统信息,不支持交易功能;2. 主流交易平台如币安、欧易等可用于交易操作;3. 区块浏览器如Etherscan、Blockchair和Etherchain用于查询交易、地…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信