我想通过antizer在试剂中使用蚂蚁设计组件,但我无法弄清楚如何在提交后从表单中提取字段值。我无法在documentation中找到任何内容。
比我更专业的人解决了这个问题?
答案 0 :(得分:1)
如果您向ant/validate-fields
函数提供回调,它将收到两个参数:errors
和values
。
如果输入有效,errors
将为null
。
第二个参数将始终包含当前表单数据。
;; Receive the output of `ant/validate-fields`, and react accordingly
(defn submit-form-if-valid
[errors values]
(if (nil? errors)
(println "Form is valid." values)
(println "Validation failed." errors)))
(defn sample-form
(fn [props]
(let [my-form (ant/create-form)
submit-handler #(ant/validate-fields my-form submit-form-if-valid)]
[:div
[ant/form {:on-submit #(do
(.preventDefault %)
(submit-handler))}
[ant/form-item ...]
[ant/form-item ...]
[ant/form-item ...]
[ant/form-item
[ant/button {:type "primary"
:html-type "submit"}
"Submit"]]]])))
注意:就个人而言,我只使用此功能来检查errors
。每次用户更改字段时,我的表单数据都会连续记录在app-db中。所以我的提交处理程序看起来更像是这样:
(defn submit-form-if-valid
[errors _]
(when (nil? errors)
(dispatch [:sample-form/submit!])))
我的重新框架事件看起来像这样。一个事件用于更新DB中的表单数据(使用表单输入提供的键/值对),另一个用于实际提交表单:
(reg-event-db
:sample-form/update-value
[(path db/path)]
(fn [db [_ k v]]
(assoc-in db [:sample-form-data k] v)))
(reg-event-fx
:sample-form/submit!
[(path db/path)]
(fn [{:keys [db]} _]
(let [form-data (:sample-form-data db)])
;; ... send data to back-end, handle the response, etc.
))
我的每个表单输入都会调用这个事件:
[ant/form-item
(ant/decorate-field my-form "Thing #1" {:rules [{:required true}]}
[ant/input {:on-change #(dispatch [:sample-form/update-value :thing1 (-> % .-target .-value)])}])]
希望这有帮助!