upickle:反序列化期间的字符串值无效

时间:2016-06-07 21:12:26

标签: scala scala.js upickle

我在scala.js世界中相当新,所以我决定尝试一些小例子,其中一个是非常简单的获取请求,解析将json返回到scala实体。

请找到以下代码:

def loadAndDisplayPosts(postsElement: Element) = {
  jQuery.get(
    url = "/posts",
    success = {
      (data: js.Any) =>
        val stringify = JSON.stringify(data)
        console.log(stringify)
        val posts = read[List[Post]](stringify)
        console.log(posts.size)
        posts.map(render).foreach(postsElement.appendChild)
    }
  )
}

console.log(stringify)返回以下json:

[
  {
    "title": "Some fancy title",
    "content": "some very long string with \"escaped\" characters",
    "tags": [
      "algorithms"
    ],
    "created": 1474606780004
  }
]

当一切都归结为

read[List[Post]](stringify)

我得到以下异常:

upickle.Invalid$Data: String (data: 1474606780004)

所以问题是:是否有任何错误?这种行为是否有正当理由?

使用的库版本:

"com.lihaoyi" %%% "upickle" % "0.4.1"

编辑:

添加实体本身:

case class Post(title: String,
                  content: String,
                  tags: List[String] = List.empty,
                  created: Long = System.currentTimeMillis())

编辑2:

以下代码产生相同的错误:

val post = Post("Some title", "some \"content\"", List("algorithms"), 1474606780004L)
val json = write[List[Post]](List(post))

提前感谢您的澄清。

2 个答案:

答案 0 :(得分:2)

嗯,实际上正确答案就在这里:upickle read from scalaJS - upickle.Invalid$Data: String (data: 1)

字符串只是部分正确答案。你也可以使用 Double (至少你可以在scala方面免费获得免费实际转换)。

所以我最终得到了以下可以正常工作的实体:

case class Post(title: String,
                  content: String,
                  tags: List[String] = List.empty,
                  created: Double = System.currentTimeMillis())

答案 1 :(得分:0)

uPickle将Long序列化为JSON中的字符串,因为JavaScript编号不能代表所有Long

因此,对象的created字段应为字符串 "1474606780004"