如果存在隐式Json转换器,则播放2.2匹配

时间:2013-11-16 06:48:11

标签: scala playframework-2.2

我已将所有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)

1 个答案:

答案 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)
    }
  }