clojure destructing
destructing表示通过数据结果常量来模式匹配参数
vector可以匹配接口sequential实现, map常量可以匹配接口associative的实现
vector通过顺序匹配,可以匹配支持nth的任意类, 可选的& 表示匹配剩余的选项 , :as表示匹配整个参数
(let [[a b & c :as d] [1 2 3 4 5 6]]
[a b c d])
==>[1 2 (3 4 5 6) [1 2 3 4 5 6]
Map通过键来匹配相对应得, 可选的 :as表示匹配整个对象, :or 表示匹配的默认值(如果匹配不存在的话),
(let [{a 2 b 4 c 5 d 8 :as e :or {d 0}} { 0 1 2 3 4 5 }]
[a b c d e ])
==>[3 5 nil 0 {0 1, 2 3, 4 5}]
通过 :keys :strs :syms + [键字符串] 来简化匹配
(let [{:keys [a b c]} {:a 1 :b 2 :c 3}]
[ a b c ])
可以符合vector和map
(let [[{:strs [a ] :as b} c & d :as f] [ { "a" 1 2 3} 4 5 6 7]]
[a b c d f])
==>[1 {"a" 1, 2 3} 4 (5 6 7) [{"a" 1, 2 3} 4 5 6 7]]
compojure中GET的参数绑定
如果绑定参数是vector的话,只绑定到请求参数上的,如果是Map的则绑定到request对象上
destructing表示通过数据结果常量来模式匹配参数
vector可以匹配接口sequential实现, map常量可以匹配接口associative的实现
vector通过顺序匹配,可以匹配支持nth的任意类, 可选的& 表示匹配剩余的选项 , :as表示匹配整个参数
(let [[a b & c :as d] [1 2 3 4 5 6]]
[a b c d])
==>[1 2 (3 4 5 6) [1 2 3 4 5 6]
Map通过键来匹配相对应得, 可选的 :as表示匹配整个对象, :or 表示匹配的默认值(如果匹配不存在的话),
(let [{a 2 b 4 c 5 d 8 :as e :or {d 0}} { 0 1 2 3 4 5 }]
[a b c d e ])
==>[3 5 nil 0 {0 1, 2 3, 4 5}]
通过 :keys :strs :syms + [键字符串] 来简化匹配
(let [{:keys [a b c]} {:a 1 :b 2 :c 3}]
[ a b c ])
可以符合vector和map
(let [[{:strs [a ] :as b} c & d :as f] [ { "a" 1 2 3} 4 5 6 7]]
[a b c d f])
==>[1 {"a" 1, 2 3} 4 (5 6 7) [{"a" 1, 2 3} 4 5 6 7]]
compojure中GET的参数绑定
如果绑定参数是vector的话,只绑定到请求参数上的,如果是Map的则绑定到request对象上