这是我的搜索对象:
package models.helper
import play.api.libs.json.Format
import play.api.libs.json.JsValue
import play.api.libs.json.JsObject
import play.api.libs.json.JsString
case class Search (name: String, `type`:String){
implicit object SearchFormat extends Format[Search] {
def reads(json: JsValue): Search = Search(
(json \ "name").as[String],
(json \ "type").as[String]
)
def writes(s: Search): JsValue = JsObject(Seq(
"name" -> JsString(s.name),
"type" -> JsString(s.`type`)
))
}
}
我在使用WS调用web服务时尝试使用此类:
val search = response.json.as[Search]
但scala编译器一直在抱怨这条线:
没有找到类型models.helper.Search的Json反序列化器。尝试 为此类型实现隐式读取或格式。
有人能告诉我我做错了吗?
答案 0 :(得分:21)
确实这个例子是错误的。您需要在隐式范围内使用隐式Format[Search]
值。
在您的情况下,Format[Search]
被定义为类Search
的嵌套值,因此您只能从Search
的实例访问它。
所以,你想要做的是在另一个地方定义它,在那里可以引用它而不必创建Search
的实例,例如在Formats
对象中:
object Formats {
implicit SearchFormat extends Format[Search] {
…
}
}
然后您可以按如下方式使用它:
import Formats.SearchFormat
val search = response.json.as[Search]
您还可以通过在Format[Search]
类的随播对象中定义Search
值来摆脱导入税。实际上,当Scala编译器需要给定类型的隐式值时,它会自动查找类型参数的伴随对象:
case class Search(name: String, `type`: String)
object Search {
implicit object SearchFormat extends Format[Search] {
…
}
}
然后您可以使用它而无需导入它:
val search = response.json.as[Search]