Enumeration自动推导找不到Encoder
Automatic derivation of Enumeration can't find Encoder
我有一个这样的案例class:
case class Admin(name: String, role: Role)
Role
是枚举
object Role extends Enumeration {
type Role = Value
val Manager = Value
}
当我尝试:
import io.circe.generic.auto._, io.circe.syntax._
val response = Admin("John", Role.Manager).asJson.noSpaces
我收到隐式编码器未找到错误。
not enough arguments for method asJson: (implicit encoder: io.circe.Encoder[Admin])io.circe.Json. Unspecified value parameter encoder.
我想这个错误是由于枚举,所以我改为:
trait Role
object Role {
object Manager extends Role
}
但这也行不通。
最后,我尝试了:
trait Role
object Manager extends Role
并没有成功。有谁可以帮助我吗?谢谢!
enumeratum-circe 启用以下语法
object CirceEnumeratumExample extends App {
import enumeratum._
import io.circe.generic.auto._, io.circe.syntax._
sealed trait Role extends EnumEntry
case object Role extends Enum[Role] with CirceEnum[Role] {
case object Manager extends Role
case object User extends Role
val values = findValues
}
case class Admin(name: String, role: Role)
val response = Admin("John", Role.Manager).asJson.noSpaces
println(response)
}
输出
{"name":"John","role":"Manager"}
哪里
libraryDependencies += "com.beachape" %% "enumeratum" % "1.5.13",
libraryDependencies += "com.beachape" %% "enumeratum-circe" % "1.5.21"
我有一个这样的案例class:
case class Admin(name: String, role: Role)
Role
是枚举
object Role extends Enumeration {
type Role = Value
val Manager = Value
}
当我尝试:
import io.circe.generic.auto._, io.circe.syntax._
val response = Admin("John", Role.Manager).asJson.noSpaces
我收到隐式编码器未找到错误。
not enough arguments for method asJson: (implicit encoder: io.circe.Encoder[Admin])io.circe.Json. Unspecified value parameter encoder.
我想这个错误是由于枚举,所以我改为:
trait Role
object Role {
object Manager extends Role
}
但这也行不通。
最后,我尝试了:
trait Role
object Manager extends Role
并没有成功。有谁可以帮助我吗?谢谢!
enumeratum-circe 启用以下语法
object CirceEnumeratumExample extends App {
import enumeratum._
import io.circe.generic.auto._, io.circe.syntax._
sealed trait Role extends EnumEntry
case object Role extends Enum[Role] with CirceEnum[Role] {
case object Manager extends Role
case object User extends Role
val values = findValues
}
case class Admin(name: String, role: Role)
val response = Admin("John", Role.Manager).asJson.noSpaces
println(response)
}
输出
{"name":"John","role":"Manager"}
哪里
libraryDependencies += "com.beachape" %% "enumeratum" % "1.5.13",
libraryDependencies += "com.beachape" %% "enumeratum-circe" % "1.5.21"