clojurescript - Clojurescript Om 中的应用程序状态和组件本地状态有什么区别?

标签 clojurescript om

我已经阅读了 David Nolen 的基本 Om 教程,但我仍然对应用程序状态和组件本地状态之间的区别感到有些困惑。当引用游标时,它是否也引用了其中之一或两者?

最佳答案

据我了解:

应用程序状态是组件树中的所有组件都可以通过游标访问的“全局”状态。这是您的应用程序所处的状态,基本上是 Om 呈现的状态。因此,例如,如果您正在编写聊天程序,应用程序状态将包含对话中的用户列表和所有已发送的消息,或其他内容。

组件本地状态是单个组件本地的状态,在该组件之外无法看到。它可以通过传递 {:init-state } 来构建,或者通过实现 IInitState 并从 init-state 返回一个映射来设置 - 或者两者兼而有之(在这种情况下,它们被组合在一起)。 David Nolen 建议本地状态应该只用于 transient ,例如当前在拖放组件中按下鼠标,而所有其他状态都应该是应用程序状态。也就是说,如果你有一个选项卡小部件,当前选择的选项卡应该设置在应用程序状态(不是本地状态!),但是如果选项卡被拖到一个新位置,当前位置和鼠标状态将是(暂时 -直到拖动操作完成)存储在组件本地状态。 core.async channel 之类的东西也可以存储在本地状态中(尽管我也将它们(并且看到其他人也这样做)存​​储在共享状态和附加数据中 - 有关两者的详细信息,请参见下文)

游标仅适用于应用程序状态,就像进入其中的窗口一样,因此树下的组件只能访问它们实际需要访问的数据。

应用程序状态总是通过游标(教程中的应用程序)访问,修改应用程序状态是通过游标完成的 - om/update!和 om/交易!将游标作为他们的第一个参数。你也可以直接用reset设置应用状态atom!和交换!,但大卫建议不要这样做,因为这样做你会失去一些 Om 更高级的功能(比如收到更改增量通知)。

本地状态可以通过 IRenderState 接收,也可以通过 om/get-state 直接访问。您可以使用 om/set-state 设置本地状态!和 om/upate-state!。所有这三个都需要一个组件支持对象(教程中的所有者)。

Om 中还有第三种状态:共享状态。共享状态使用 {:shared ...} 选项传递给 om/root,并且可以使用 om/get-shared 从该根下树中的任何组件访问。这与应用程序状态的区别在于,应用程序状态是通过光标路径缩小的——也就是说,子组件可能无法访问整个应用程序状态——而共享状态始终是可访问的。此外,修改应用程序状态会导致组件重新渲染,而共享状态不会触发渲染。

顺便说一句,实际上还有第四种类型 - 您可以使用 {:opts ...} 选项通过构建将附加数据传递给组件。这是存在于 Om/react 生命周期之外的数据——也就是说,您可以从组件访问它的不可变数据,但组件不会以任何方式管理它。这似乎对配置数据最有用。

关于clojurescript - Clojurescript Om 中的应用程序状态和组件本地状态有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22883759/

相关文章:

clojurescript - 如何检查 om 对象?

clojurescript - OM 组件与普通函数

clojurescript - 在 Om 中传递 App Atom 与 Ref-Cursors

clojure - ClojureScript 中向量的索引

clojurescript - 当我将它们分配给局部变量时,为什么 js 函数会失败?

emacs - Clojure - 在没有 project.clj 的情况下启动 REPL

css - 使用 om (/react) 显示隐藏的 div

clojurescript - ArangoDB Foxx 和 Clojure 脚本

reactjs - 是否可以在 ClojureScript Om 应用程序中重用现有的 React 组件?

clojurescript - Cojurescript Om : handling local state changes in different components