0

0

Pulsy Readme updated

心靈之曲

心靈之曲

发布时间:2024-10-06 14:06:20

|

834人浏览过

|

来源于dev.to

转载

pulsy readme updated

pulsy - react 的轻量级状态管理库

pulsy 是一个轻量级、灵活且易于使用的 react 状态管理库,提供持久性、中间件、记忆化、计算和组合存储、时间旅行和 devtools 集成等功能。它可以帮助您有效地管理 react 应用程序中的全局状态,而无需不必要的复杂性。

特征

  • 全局状态管理:使用简单的存储 api 管理跨组件的状态。
  • 持久化:自动将存储数据持久化到localstorage或自定义存储解决方案中。
  • 中间件:通过中间件功能修改和处理商店更新。
  • 记忆:通过使用记忆状态值避免不必要的渲染。
  • 计算存储:从现有存储中导出并计算状态。
  • 可组合存储:将多个存储组合成一个存储以进行模块化状态管理。
  • 时间旅行:倒回和前进状态更改。
  • devtools 集成:在开发模式下跟踪和调试状态更新。

安装


npm install pulsy
# or
yarn add pulsy



基本用法

第 1 步:配置 pulsy

pulsy 可以进行全局配置,以启用 devtools、默认记忆、持久性和用于商店创建和更新的回调挂钩。


import { configurepulsy } from 'pulsy';

configurepulsy({
  enabledevtools: process.env.node_env === 'development',
  persist: true, // globally enable persistence by default
  defaultmemoize: true, // enable memoization for all stores by default
  onstorecreate: (name, initialvalue) => console.log(`store "${name}" created! initial value:`, initialvalue),
  onstoreupdate: (name, newvalue) => console.log(`store "${name}" updated! new value:`, newvalue),
});


第 2 步:创建商店

要创建商店,请使用 createstore 函数。存储保存全局状态,可以在 react 应用程序中的任何位置使用。


import { createstore } from 'pulsy';

// create a store named 'counter' with an initial value of 0
createstore('counter', 0);


第 3 步:在组件中使用 store

pulsy 提供了 usepulsy 钩子来访问和更新 react 组件中的 store 的值。让我们创建一个计数器组件:


import usepulsy from 'pulsy';

function countercomponent() {
  const [count, setcount] = usepulsy<number>('counter');

  const increment = () => setcount((prev) => prev + 1);

  return (
    <div>
      <p>current count: {count}</p>
      <button onclick={increment}>increment</button>
    </div>
  );
}

export default countercomponent;



坚持

pulsy 可以轻松地将存储值保存在 localstorage 或任何其他自定义存储系统中。只需在创建商店时传递 persist 选项即可。


createstore('counter', 0, { persist: true });


计数器存储的值现在将在页面重新加载时保持不变。

示例:使用自定义存储

您还可以配置 pulsy 使用自定义存储,例如 sessionstorage 或任何其他实现 storage 接口的存储引擎:


createstore('sessioncounter', 0, {
  persist: {
    storage: sessionstorage, // use sessionstorage instead of localstorage
    serialize: (value) => json.stringify(value),
    deserialize: (value) => json.parse(value),
  },
});


这会将 sessioncounter 存储在 sessionstorage 中。


中间件

中间件允许您在提交存储更新之前拦截和修改它们。您可以在创建商店时添加中间件,或者稍后使用 addmiddleware 添加中间件。


const loggingmiddleware = (nextvalue, prevvalue, storename) => {
  console.log(`[${storename}] changed from ${prevvalue} to ${nextvalue}`);
  return nextvalue;
};

createstore('counter', 0, { middleware: [loggingmiddleware] });


在此示例中,中间件会记录计数器存储中的每个状态更改。

示例:异步中间件

pulsy 支持异步中间件来处理 api 调用等异步任务:


const asyncmiddleware = async (nextvalue, prevvalue, storename) => {
  console.log(`fetching data before updating ${storename}...`);
  const data = await fetch('https://api.example.com/data').then((res) => res.json());
  return nextvalue + data.amount;
};

createstore('counter', 0, { middleware: [asyncmiddleware] });


在此示例中,中间件在更新存储之前从 api 获取一些数据。


时间旅行状态管理

pulsy 允许您使用 usetimetravel 挂钩管理状态历史记录,使您能够撤消和重做状态更改。


import { usetimetravel } from 'pulsy';

function timetravelcounter() {
  const [count, setcount, undo, redo] = usetimetravel<number>('counter');

  return (
    <div>
      <p>count: {count}</p>
      <button onclick={() => setcount(count + 1)}>increment</button>
      <button onclick={undo}>undo</button>
      <button onclick={redo}>redo</button>
    </div>
  );
}


示例:显示状态历史记录

您可以使用usetimetravel提供的historyref访问状态更改的完整历史记录:

GentleAI
GentleAI

GentleAI是一个高效的AI工作平台,为普通人提供智能计算、简单易用的界面和专业技术支持。让人工智能服务每一个人。

下载

function historycounter() {
  const [count, setcount, undo, redo, history] = usetimetravel<number>('counter');

  return (
    <div>
      <p>count: {count}</p>
      <button onclick={() => setcount(count + 1)}>increment</button>
      <button onclick={undo}>undo</button>
      <button onclick={redo}>redo</button>
      <p>history: {history.join(', ')}</p>
    </div>
  );
}



计算存储

计算存储从其他存储中获取其状态。 pulsy 允许您创建其值基于一个或多个其他商店的商店。


import { createcomputedstore } from 'pulsy';

createcomputedstore('doublecounter', () => {
  const counter = getstorevalue<number>('counter');
  return counter * 2;
}, ['counter']);


这里,每当计数器存储发生变化时,doublecounter 就会自动更新。

示例:显示组件中的计算存储

您现在可以像访问常规存储一样访问计算存储:


function doublecountercomponent() {
  const [doublecount] = usepulsy<number>('doublecounter');

  return (
    <div>
      <p>double counter: {doublecount}</p>
    </div>
  );
}



组合商店

pulsy 支持将多个商店合并为一个商店。这对于通过将相关状态分组在一起来管理复杂状态特别有用。


import { composestores } from 'pulsy';

const [getcomposedstore, setcomposedstore] = composestores('userprofile', {
  username: 'usernamestore',
  age: 'agestore',
});

const userprofilecomponent = () => {
  const userprofile = getcomposedstore();

  return (
    <div>
      <p>username: {userprofile.username}</p>
      <p>age: {userprofile.age}</p>
    </div>
  );
};


示例:更新组合存储

您还可以使用 setcompositedstore 函数更新组合存储的特定部分:


setcomposedstore({
  username: 'newusername',
});



命名空间存储

pulsy 允许您创建命名空间存储,以保持相关存储的组织性并避免大型应用程序中的命名冲突。


import { createnamespacedstore } from 'pulsy';

// create a namespaced store for user-related data
const useuserstore = createnamespacedstore('user');

function usercomponent() {
  const [username, setusername] = useuserstore<string>('username');

  return (
    <div>
      <p>username: {username}</p>
      <button onclick={() => setusername('newusername')}>update username</button>
    </div>
  );
}


这里,所有与用户相关的存储(例如,user:username、user:age)都分组在用户命名空间下。


开发工具集成

pulsy 与浏览器 devtools 集成,以帮助跟踪和调试商店更新。启用 devtools 后,您将在控制台中看到有关商店更新、状态更改和性能测量的日志。


configurepulsy({
  enabledevtools: true, // logs detailed store activity to the console
});


pulsy 记录有用的信息,例如何时创建或更新商店、中间件执行以及开发模式下的时间旅行操作。


完整示例:使用持久性和中间件管理用户配置文件

让我们将多个 pulsy 功能组合到一个示例中。


import { createStore, usePulsy, configurePulsy } from 'pulsy';

// Global configuration
configurePulsy({
  enableDevTools: true,
  persist: true,
});

// Middleware to log store updates
const loggingMiddleware = (nextValue, prevValue, storeName) => {
  console.log(`Store ${storeName}

 updated from ${prevValue} to ${nextValue}`);
  return nextValue;
};

// Create a store for user profile
createStore('userProfile', {
  username: 'guest',
  age: 25,
}, { middleware: [loggingMiddleware], persist: true });

// Component to manage user profile
function UserProfileComponent() {
  const [userProfile, setUserProfile] = usePulsy('userProfile');

  const updateUsername = () => {
    setUserProfile((prevProfile) => ({
      ...prevProfile,
      username: 'newUsername',
    }));
  };

  return (
    <div>
      <p>Username: {userProfile.username}</p>
      <p>Age: {userProfile.age}</p>
      <button onClick={updateUsername}>Change Username</button>
    </div>
  );
}

export default UserProfileComponent;


在此示例中,userprofile 存储由中间件持久保存、记录,并可通过 usepulsy 挂钩访问。 userprofilecomponent 在简单的 ui 中显示和更新商店。


结论

pulsy 是一个强大且灵活的 react 状态管理库,为持久性、中间件、计算存储、时间旅行和 devtools 提供开箱即用的支持。其简单的 api 和广泛的功能使其适用于小型和大型应用程序。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

183

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

226

2025.12.18

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1958

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

658

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2401

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

136

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

47

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号