首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >用Om Next读取输入

用Om Next读取输入
EN

Stack Overflow用户
提问于 2016-05-26 18:12:03
回答 1查看 238关注 0票数 0

我正在尝试理解如何从om.next中的文本框中读取状态。据我所知,我们不再使用core.async

作为一个小例子,考虑写一个文本框并将其绑定到一个段落元素,这样您输入的文本就会自动出现在屏幕上。

代码语言:javascript
运行
复制
(def app-state (atom {:input-text "starting text"}))


 (defn read-fn
   [{:keys [state] :as env} key params]
   (let [st @state]
     (if-let [[_ v] (find st key)]
       {:value v}
       {:value :not-found})))

 (defn mutate-fn
   [{:keys [state] :as env} key {:keys [mytext]}]
   (if (= 'update-text key)
     {:value {:keys [:input-text]}
      :action
      (fn []
        (swap! state assoc :input-text mytext))}
     {:value :not-found}))

(defui RootView
   static om/IQuery
   (query [_]
          [:input-text])
   Object
   (render [_]
           (let [{:keys [input-text]} (om/props _)]
             (dom/div nil
                      (dom/input
                       #js {:id "mybox"
                            :type "text"
                            :value input-text
                            :onChange #(om/transact! _ '[(update-text {:mytext (.-value (gdom/getElement "mybox"))})])
                            })
                      (dom/p nil input-text)))))

这不管用。

  1. 在触发onChange窗体中的input事件时,引用的表达式不会从框中获取文本。
  2. 第一个突变触发和更新,但随后的突变不会触发。即使状态没有改变,查询应该从app-state读取字符串并强制文本保持不变吗?
EN

回答 1

Stack Overflow用户

发布于 2016-05-27 02:10:59

我会让:onChange事件看起来像这样:

代码语言:javascript
运行
复制
:onChange (fn (_)
            (let [v (.-value (gdom/getElement "mybox"))]
              #(om/transact! this `[(update-text {:mytext ~v})])))

在这里,v的值实际上是经过的。但是,om/transact!还需要一个组件或调节器作为其第一个参数传递。这里我传递的是this,它将是根组件。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37468213

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档