Play Mongo 是一个专门为 Play Framework 开发的 MongoDB 模块,该模块提供了一个隐式方法可以简化 Play Json 的开发工作。
通常情况下,我们需要借助 Play Json 提供的Json.format
宏为 case class 提供隐式的Reads和Writes,
import models._
import play.api.libs.json.Format
package object models {
implicit val emailFormat = Json.format[Email]
implicit val personFormat = Json.format[Person]
...
implicit val addressFormat = Json.format[Address]
}
每当我们在models包创建一个新的 case class,就需要在这里添加一个相应的隐式 Format 对象。并且被依赖的 case class 需要先定义,否则仍然会报编译错误。编写这些样板代码是很枯燥无味的,为此我们在 Play Mongo 中实现了一个 implicit macro, 只需要一行代码,便可以为所有的 case class 生成隐式的Reads和Writes,
import scala.language.experimental.macros
import play.api.libs.json.Format
import cn.playscala.mongo.codecs.macrocodecs.JsonFormatMacro
package object models {
implicit def formats[T <: Product]: Format[T] = macro JsonFormatMacro.materializeJsonFormat[T]
}
需要注意的是,该隐式方法需要定义在 package object 下,例如当定义在 package object models
下时,该隐式方法将会对 models 包下所有的 case class 生效。 小伙伴们,赶紧打开build.sbt
,添加依赖尝尝鲜吧!
libraryDependencies += "cn.playscala" % "play-mongo_2.12" % "0.2.0"