3

我在这里真的很困惑,我可能遗漏了一些明显的东西,所以如果有人能指出我正确的方向,那就太好了。

我有以下函数,它返回 SimpleResult 类型的未来,但它有一个 unit 。我不确定为什么会这样说,因为我正在映射 futureList 结果

  def find(key: String, value: String) = Future[SimpleResult] {

  val cursor: Cursor[JsObject] = coll.
    find(Json.obj(key -> value)).
    cursor[JsObject]

  val futureList: Future[List[JsObject]] = cursor.collect[List]()

  val futureResult: Future[SimpleResult] = futureList.map { item =>

    if(item.isEmpty) {

        Ok(JsArray()).as(JSON)
    }
    else 
         Ok(Json.toJson(item))     
 }
} 

编辑

根据 Marth 给出的建议,我已将其更改为以下内容

  def find(key: String, value: String) = Future[SimpleResult] {

  val cursor: Cursor[JsObject] = coll.
    find(Json.obj(key -> value)).
    cursor[JsObject]

  val futureList: Future[List[JsObject]] = cursor.collect[List]()

   futureList.map { item =>  Ok(Json.toJson(item))    }

}

Eclipse 对以下内容发出警告

类型不匹配; 发现:scala.concurrent.Future[play.api.mvc.SimpleResult] 需要:play.api.mvc.SimpleResult

尽管该函数旨在返回 scala.concurrent.Future[play.api.mvc.SimpleResult]

4

1 回答 1

7

这是一个语法错误。

def find(key: String, value: String): Future[SimpleResult] = {

  val cursor: Cursor[JsObject] = coll.
    find(Json.obj(key -> value)).
    cursor[JsObject]

  val futureList: Future[List[JsObject]] = cursor.collect[List]()

  futureList.map { item =>  Ok(Json.toJson(item))    }

}

请注意第一行中的“:”和“=”符号。如果没有冒号,您实际上只是在调用 Future.apply[SimpleResult],它接受一个参数:一个应该返回 SimpleResult 的函数。这就是你得到类型不匹配的原因:你在 Future 的主体中返回一个 Future。

于 2014-01-04T22:31:05.860 回答