[MST] Create Dynamic Types and use Type Composition to Extract Common Functionality
Since MST offers a runtime type system, it can create and compose types on the fly, making it possible to reuse logic in new and powerful ways.
In this lesson you will learn:
- That MST types are immutable and composed together behind the scenes
- How to compose types explicitly by using
types.compose
- How to create dynamic, parameterized types by leveraging that MST types are first class javascript citizens
import { types, flow, getSnapshot, onSnapshot } from "mobx-state-tree" export function createStorable(collection, attribute) { return types.model({}).actions(self => ({ save: flow(function* save() { try { yield window.fetch(`http://localhost:3001/${collection}/${self[attribute]}`, { method: "PUT", headers: { "Content-Type": "application/json" }, body: JSON.stringify(getSnapshot(self)) }) } catch (e) { console.error("Uh oh, failed to save: ", e) } }), afterCreate() { onSnapshot(self, self.save) } })) }
import { types, flow, getParent, applySnapshot, getSnapshot, onSnapshot } from "mobx-state-tree" import { WishList } from "./WishList" import { createStorable } from "./Storable" const User = types.compose( types .model({ id: types.identifier(), name: types.string, gender: types.enumeration("gender", ["m", "f"]), wishList: types.optional(WishList, {}), recipient: types.maybe(types.reference(types.late(() => User))) }) .actions(self => ({ getSuggestions: flow(function* getSuggestions() { const response = yield window.fetch( `http://localhost:3001/suggestions_${self.gender}` ) self.wishList.items.push(...(yield response.json())) }) })), createStorable("users", "id") )
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2017-02-01 [TypeScript] Use the never type to avoid code with dead ends using TypeScript
2016-02-01 [Regex Expression] Use Shorthand to Find Common Sets of Characters
2016-02-01 [Regex Expression] Find Sets of Characters
2016-02-01 [Regular Expressions] Find Repeated Patterns
2016-02-01 [Regular Expressions] Find Plain Text Patterns