如何让 CKEditor 反应组件在 ClojureScript 中可用
How to get CKEditor react component usable in ClojureScript
我无法让 CKEditor 反应组件在 ClojureScript 项目中工作。
当我尝试使用组件时
(ns simple.core
(:require [reagent.core :as reagent]
[re-frame.core :as rf]
[clojure.string :as str]
[simple.routes :as routes]
["ckeditor4-react" :as ck :default CKEditor]
))
...
[:> CKEditor]
我明白了
template.cljs:312 Uncaught Error: Assert failed: Expected React component in: [:> nil]
(in simple.core.ui)
(or (string? comp) (fn? comp))
at Object.reagent$impl$template$vec_to_elem [as vec_to_elem] (template.cljs:312)
at Object.reagent$impl$template$as_element [as as_element] (template.cljs:329)
at template.cljs:403
at core.cljs:5598
at core.cljs:5598
at Object.cljs$core$IKVReduce$_kv_reduce$arity (core.cljs:5602)
at Object.cljs$core$_kv_reduce [as _kv_reduce] (core.cljs:700)
at Object.cljs$core$reduce_kv [as reduce_kv] (core.cljs:2543)
at reagent$impl$template$make_element (template.cljs:401)
at Object.reagent$impl$template$native_element [as native_element] (template.cljs:285)
我创建了一个简单的 github 项目来说明。
https://github.com/madhat2r/shadow-re-frame-simple-example
如果您克隆它并按照自述文件中的说明进行操作,您就可以重现。
感谢您的帮助!
事实证明这是 :require
使用 :default
的问题,您必须使用
["ckeditor4-react" :as CKEditor]
...
[:> CKEditor {:onBeforeLoad (fn [ck] (set! (.-disableAutoInline ck) true))}]
Shadow-cljs: https://shadow-cljs.github.io/docs/UsersGuide.html#_about_default_exports
注意:上面的onBeforeLoad函数修复了当前版本的一个bug。留给可能遇到它的任何人。 https://github.com/ckeditor/ckeditor4-react/issues/57
我无法让 CKEditor 反应组件在 ClojureScript 项目中工作。
当我尝试使用组件时
(ns simple.core
(:require [reagent.core :as reagent]
[re-frame.core :as rf]
[clojure.string :as str]
[simple.routes :as routes]
["ckeditor4-react" :as ck :default CKEditor]
))
...
[:> CKEditor]
我明白了
template.cljs:312 Uncaught Error: Assert failed: Expected React component in: [:> nil]
(in simple.core.ui)
(or (string? comp) (fn? comp))
at Object.reagent$impl$template$vec_to_elem [as vec_to_elem] (template.cljs:312)
at Object.reagent$impl$template$as_element [as as_element] (template.cljs:329)
at template.cljs:403
at core.cljs:5598
at core.cljs:5598
at Object.cljs$core$IKVReduce$_kv_reduce$arity (core.cljs:5602)
at Object.cljs$core$_kv_reduce [as _kv_reduce] (core.cljs:700)
at Object.cljs$core$reduce_kv [as reduce_kv] (core.cljs:2543)
at reagent$impl$template$make_element (template.cljs:401)
at Object.reagent$impl$template$native_element [as native_element] (template.cljs:285)
我创建了一个简单的 github 项目来说明。
https://github.com/madhat2r/shadow-re-frame-simple-example
如果您克隆它并按照自述文件中的说明进行操作,您就可以重现。
感谢您的帮助!
事实证明这是 :require
使用 :default
的问题,您必须使用
["ckeditor4-react" :as CKEditor]
...
[:> CKEditor {:onBeforeLoad (fn [ck] (set! (.-disableAutoInline ck) true))}]
Shadow-cljs: https://shadow-cljs.github.io/docs/UsersGuide.html#_about_default_exports
注意:上面的onBeforeLoad函数修复了当前版本的一个bug。留给可能遇到它的任何人。 https://github.com/ckeditor/ckeditor4-react/issues/57