首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >试剂盒中的:<>是什么?

试剂盒中的:<>是什么?
EN

Stack Overflow用户
提问于 2020-10-03 15:59:33
回答 2查看 387关注 0票数 6

我不理解以下代码clojure re-frame todomvc中的标记":<>“

代码语言:javascript
复制
(defn todo-app
  []
  [:<>
   [:section#todoapp
    [task-entry]
    (when (seq @(subscribe [:todos]))
      [task-list])
    [footer-controls]]
   [:footer#info
    [:p "Double-click to edit a todo"]]])

有人能在这方面帮我吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-10-03 16:58:49

这就是创建一个React片段:

https://reactjs.org/docs/fragments.html

票数 6
EN

Stack Overflow用户

发布于 2020-10-05 03:44:23

在前面的回答中添加了更多细节,fragment被拼接到周围的列表中,而不是创建子元素。通过这种方式,它类似于Clojure ~@中的unquoted-splicing运算符,而不是常规的unquote运算符~。举个例子:

代码语言:javascript
复制
(defn middle-seq       [] [    :d :e :f])
(defn middle-seq-frag  [] [:<> :d :e :f])

当用来创建Reagent组件时,我们看到了不同之处:

代码语言:javascript
复制
[:a :b :c (middle-seq)      :g :h :i]    ;=> [:a :b :c [:d :e :f] :g :h :i]
[:a :b :c (middle-seq-frag) :g :h :i]    ;=> [:a :b :c  :d :e :f  :g :h :i]

否则,您将不得不重新构造输入并使用concat

代码语言:javascript
复制
(vec
  (concat
    [:a :b :c]
    (middle-seq) 
    [:g :h :i] ))          ;=> [:a :b :c :d :e :f :g :h :i]
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64181996

复制
相关文章

相似问题

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