在 selmer 中遍历地图
Iterate over a map in selmer
我想在 selmer 中迭代地图,以允许我打印键和值的方式。据我所知,这是不支持开箱即用的,所以我尝试了以下方法:
(defn mapper-tag [args context-map content]
(when-let [map-data (get context-map (keyword (first args))
(get context-map (first args)))]
(apply str (for [[k v] map-data]
(selmer.parser/render (get-in content [:mapper :content]) {:key k :val v})))))
(selmer.parser/add-tag! :mapper mapper-tag :endmapper)
(selmer.parser/render "{% mapper m %}KEY {{key}} \n{% endmapper %}" {:m {:a 1 :b 1}})
我希望这会输出类似
KEY a
KEY b
但它输出
KEY
KEY
有什么指点吗?
Clojure 中的映射是序列,因此您可以只使用 selmer for
:
(selmer.filters/add-filter! :key key)
(selmer.filters/add-filter! :val val)
(selmer.parser/render "{% for item in m %} KEY is {{item|key}} VALUES is {{item|val}}\n{% endfor %}" {:m {:a 1 :b 1}})
Selmer 的内置 {% for %}
循环 allows for destructuring,因此您可以在模板中拉出 key/value:
(selmer.parser/render
"{% for key,val in m %}KEY: {{key}}, VALUE: {{val}}\n{% endfor %}"
{:m {:a 1 :b 1}})
输出:
KEY: a, VALUE: 1
KEY: b, VALUE: 1
我想在 selmer 中迭代地图,以允许我打印键和值的方式。据我所知,这是不支持开箱即用的,所以我尝试了以下方法:
(defn mapper-tag [args context-map content]
(when-let [map-data (get context-map (keyword (first args))
(get context-map (first args)))]
(apply str (for [[k v] map-data]
(selmer.parser/render (get-in content [:mapper :content]) {:key k :val v})))))
(selmer.parser/add-tag! :mapper mapper-tag :endmapper)
(selmer.parser/render "{% mapper m %}KEY {{key}} \n{% endmapper %}" {:m {:a 1 :b 1}})
我希望这会输出类似
KEY a
KEY b
但它输出
KEY
KEY
有什么指点吗?
Clojure 中的映射是序列,因此您可以只使用 selmer for
:
(selmer.filters/add-filter! :key key)
(selmer.filters/add-filter! :val val)
(selmer.parser/render "{% for item in m %} KEY is {{item|key}} VALUES is {{item|val}}\n{% endfor %}" {:m {:a 1 :b 1}})
Selmer 的内置 {% for %}
循环 allows for destructuring,因此您可以在模板中拉出 key/value:
(selmer.parser/render
"{% for key,val in m %}KEY: {{key}}, VALUE: {{val}}\n{% endfor %}"
{:m {:a 1 :b 1}})
输出:
KEY: a, VALUE: 1
KEY: b, VALUE: 1