我有以下代码,我认为我做了一些根本错误的事情。

(defn world-view [data owner opts]
  (reify
    om/IInitState
      (init-state [_]
        (om/update! data #(assoc % :world vec)))
    om/IWillMount
      (will-mount [_]
        (go (let [world (<! (get-world (:dimensions opts)))]
              (log (get-in world [9 9]))
              (om/update! data #(assoc % :world world)))))
    om/IRender
      (render [this]
        (log (get :world data))
        (apply dom/table nil
          (om/build-all row (:world data))))))

我正在进行远程 ajax 调用 om/IWillMount 像这样:

om/IWillMount
  (will-mount [_]
    (go (let [world (<! (get-world (:dimensions opts)))]
          (log (get-in world [9 9]))
          (om/update! data #(assoc % :world world)))))

我期待从远程调用返回一个二维向量,这是有效的,因为我可以使用以下命令记录数组的元素

(log (get-in world [9 9]))

然后我正在使用 om/update 更新数据结构。

但是当调用渲染时,数据似乎没有更新,我可以通过尝试记录数据结构来测试这一点

log (get :world data))

这没有记录任何内容。

我看不出我做错了什么或者为什么数据结构没有更新。

有帮助吗?

解决方案

om/update! 将光标设置为给定值,因此您基本上是在为光标分配一个函数。我相信你应该使用 om/transact! 反而。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top