我已将所有Json转换器放在一个文件JsonUtil中,然后使用convertToJson方法尝试转换传递给json的任何对象。
基本上是这样的结构:
implicit val format_A = format[A]
implicit val format_B = format[B]
def convertToJson(o: Any): JsValue =
o match {
case a: A => Json.toJson(a)
case b: B => Json.toJson(b)
case a: Any => Logger.warn("could not convert to json: "+a); JsNull
}
但有更多格式化程序/案例。当我需要转换时(出于各种原因),我不想导入所有这些含义。如果存在有效的toJson转换,是否有匹配的方法,所以我不必写所有的情况?
像:
case o: ExistJsonConversion => Json.toJson(o)
答案 0 :(得分:3)
这很有效。
def convertToJson[A](a: A)(implicit ev: Format[A] = null): JsValue = {
if (ev != null) {
Json.toJson(a)(ev)
} else {
println("oops")
JsNull
}
}
下面有一个更好的版本(也许;)
case class Perhaps[E](value: Option[E]) {
def fold[F](ifAbsent: => F)(ifPresent: E => F): F =
value.fold(ifAbsent)(ifPresent)
}
implicit def perhaps[E](implicit ev: E = null) = Perhaps(Option(ev))
def convertToJson[A](a: A)(implicit p: Perhaps[Format[A]]): JsValue = {
p.fold[JsValue] {
println("oops")
JsNull
} { implicit ev =>
Json.toJson(a)
}
}