使用 Reactables 简化 RxJS
介绍
RxJS 是一个功能强大的库,但众所周知,它的学习曲线很陡峭。
该库庞大的 API 界面,再加上向反应式编程的范式转变,可能会让新手不知所措。
我创建了 Reactables API 来简化 RxJS 的使用并简化开发人员对反应式编程的介绍。
例子
我们将构建一个简单的控件来切换用户的通知设置。
它还会将更新的切换设置发送到模拟后端,然后向用户显示一条成功消息。
安装 RxJS 和 Reactables
npm i rxjs @reactables/core
从基本的切换开始。
import { RxBuilder, Reactable } from '@reactables/core'; export type ToggleState = { notificationsOn: boolean; }; export type ToggleActions = { toggle: (payload: boolean) => void; }; export const RxNotificationsToggle = ( initialState = { notificationsOn: false, } as ToggleState ): Reactable<ToggleState, ToggleActions> => RxBuilder({ initialState, reducers: { toggle: (state) => ({ notificationsOn: !state.notificationsOn, }), }, }); const [state$, actions] = RxToggleNotifications(); state$.subscribe((state) => { console.log(state.notificationsOn); }); actions.toggle(); /* OUTPUT false true */
RxBuilder 创建一个 Reactable,它是一个包含两个项目的元组。
UI 可以订阅状态更改的 RxJS Observable。
UI 可以调用以调用状态更改的操作方法的对象。
使用 Reactable 时不需要主题。
我们可以用纯reducer函数来描述我们想要的行为。
Reactables 在幕后使用主题和各种运算符来为开发人员管理状态。
添加API调用并闪烁成功消息
Reactables 处理异步操作,其效果表示为 RxJS 运算符函数。它们可以用触发效果的操作/减速器来声明。
这使我们能够充分利用 RxJS 来处理异步逻辑。
让我们修改上面的切换示例以合并一些异步行为。为了保持简短,我们将放弃错误处理。
import { RxBuilder, Reactable } from '@reactables/core'; import { of, concat } from 'rxjs'; import { debounceTime, switchMap, mergeMap, delay } from 'rxjs/operators'; export type ToggleState = { notificationsOn: boolean; showSuccessMessage: boolean; }; export type ToggleActions = { toggle: (payload: boolean) => void; }; export const RxNotificationsToggle = ( initialState = { notificationsOn: false, showSuccessMessage: false, } ): Reactable<ToggleState, ToggleActions> => RxBuilder({ initialState, reducers: { toggle: { reducer: (_, action) => ({ notificationsOn: action.payload as boolean, showSuccessMessage: false, }), effects: [ (toggleActions$) => toggleActions$.pipe( debounceTime(500), // switchMap to unsubscribe from previous API calls if a new toggle occurs switchMap(({ payload: notificationsOn }) => of(notificationsOn) .pipe(delay(500)) // Mock API call .pipe( mergeMap(() => concat( // Flashing the success message for 2 seconds of({ type: 'updateSuccess' }), of({ type: 'hideSuccessMessage' }).pipe(delay(2000)) ) ) ) ) ), ], }, updateSuccess: (state) => ({ ...state, showSuccessMessage: true, }), hideSuccessMessage: (state) => ({ ...state, showSuccessMessage: false, }), }, });
在 StackBlitz 上查看完整示例:
反应 |有角度
让我们将 Reactable 绑定到视图。下面是使用 @reactables/react 包中的 useReactable 钩子绑定到 React 组件的示例。
import { RxNotificationsToggle } from './RxNotificationsToggle'; import { useReactable } from '@reactables/react'; function App() { const [state, actions] = useReactable(RxNotificationsToggle); if (!state) return; const { notificationsOn, showSuccessMessage } = state; const { toggle } = actions; return ( <div className="notification-settings"> {showSuccessMessage && ( <div className="success-message"> Success! Notifications are {notificationsOn ? 'on' : 'off'}. </div> )} <p>Notifications Setting:</p> <button onClick={() => toggle(!notificationsOn)}> {notificationsOn ? 'On' : 'Off'} </button> </div> ); } export default App;
就是这样!
结论
Reactables 允许我们使用纯减速器函数构建功能,而不是深入主题世界,从而帮助简化 RxJS。
然后,RxJS 被保留用于它最擅长的地方 - 组成我们的异步逻辑。
Reactables 可以扩展并做更多事情!查看文档了解更多示例,包括如何使用它们管理表单!
以上是使用 Reactables 简化 RxJS的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undress AI Tool
免费脱衣服图片

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript的作用域决定变量可访问范围,分为全局、函数和块级作用域;上下文决定this的指向,依赖函数调用方式。1.作用域包括全局作用域(任何地方可访问)、函数作用域(仅函数内有效)、块级作用域(let和const在{}内有效)。2.执行上下文包含变量对象、作用域链和this的值,this在普通函数指向全局或undefined,在方法调用指向调用对象,在构造函数指向新对象,也可用call/apply/bind显式指定。3.闭包是指函数访问并记住外部作用域变量,常用于封装和缓存,但可能引发

要使用JavaScript建立一个安全的沙盒iframe,首先利用HTML的sandbox属性限制iframe行为,例如禁止脚本执行、弹窗和表单提交;其次通过添加特定token如allow-scripts来按需放宽权限;接着结合postMessage()实现安全的跨域通信,同时严格验证消息来源和数据;最后避免常见配置错误,如未验证源、未设置CSP等,并在上线前进行安全性测试。

获取选中的单选按钮值的核心方法有两种。1.使用querySelector直接获取选中项,通过input[name="your-radio-name"]:checked选择器获取选中的元素并读取其value属性,适合现代浏览器且代码简洁;2.使用document.getElementsByName遍历查找,通过循环NodeList找到第一个checked的radio并获取其值,适合兼容旧浏览器或需要手动控制流程的场景;此外需注意name属性拼写、处理未选中情况以及动态加载内容时

JavaScript的WebWorkers和JavaThreads在并发处理上有本质区别。1.JavaScript采用单线程模型,WebWorkers是浏览器提供的独立线程,适合执行不阻塞UI的耗时任务,但不能操作DOM;2.Java从语言层面支持真正的多线程,通过Thread类创建,适用于复杂并发逻辑和服务器端处理;3.WebWorkers使用postMessage()与主线程通信,安全隔离性强;Java线程可共享内存,需注意同步问题;4.WebWorkers更适合前端并行计算,如图像处理,而

Vue3中CompositionAPI更适合复杂逻辑和类型推导,OptionsAPI适合简单场景和初学者;1.OptionsAPI按data、methods等选项组织代码,结构清晰但复杂组件易碎片化;2.CompositionAPI用setup集中相关逻辑,利于维护和复用;3.CompositionAPI通过composable函数实现无冲突、可参数化的逻辑复用,优于mixin;4.CompositionAPI对TypeScript支持更好,类型推导更精准;5.两者性能和打包体积无显着差异;6.

调试JavaScript复杂应用需系统化使用工具。1.设断点及条件断点拦截可疑流程,如函数入口、循环、异步回调前并按条件过滤;2.启用Blackboxing功能屏蔽第三方库干扰;3.结合环境判断使用debugger语句控制调试入口;4.通过CallStack追溯调用链路,分析执行路径与变量状态,从而高效定位问题根源。

类型强制转换是JavaScript中自动将一种类型的值转为另一种类型的行为,常见场景包括:1.使用 运算符时,若其中一边为字符串,另一边也会被转为字符串,如'5' 5结果为"55";2.布尔上下文中非布尔值会被隐式转为布尔类型,如空字符串、0、null、undefined等被视为false;3.null参与数值运算会转为0,而undefined会转为NaN;4.可通过显式转换函数如Number()、String()、Boolean()避免隐式转换带来的问题。掌握这些规则有助于

在JavaScript中格式化日期可通过原生方法或第三方库实现。1.使用原生Date对象拼接:通过getFullYear、getMonth、getDate等方法获取日期部分,手动拼接成YYYY-MM-DD等格式,适合轻量需求且不依赖第三方库;2.使用toLocaleDateString方法:可按本地习惯输出如MM/DD/YYYY格式,支持多语言但格式可能因环境不同而不一致;3.使用第三方库如day.js或date-fns:提供简洁语法和丰富功能,适合频繁操作或需要扩展性时使用,例如dayjs()
