基本上我正在试图弄清楚我需要传递给onload()
方法
def selectedFile(e: ReactEventI) = {
val reader = new dom.FileReader()
reader.readAsText(e.currentTarget.files.item(0))
reader.onload(
)
}
答案 0 :(得分:3)
您可以将lambda分配给onload
处理程序:
reader.onload = (e: UIEvent) => {
// Cast is OK, since we are calling readAsText
val contents = reader.result.asInstanceOf[String]
println(contents)
}
答案 1 :(得分:2)
我不喜欢使用回调,而是喜欢使用模式匹配和map
这样:
def printFileContent(file: dom.File) =
readTextFile(file).map {
case Right(fileContent) => println(s"File content: $fileContent")
case Left(error) => println(s"Could not read file ${file.name}. Error is: $error")
}
代码:
/** In the future, returns either the file's content, or an error, if something went wrong */
def readTextFile(fileToRead: dom.File): Future[Either[DOMError, String]] = {
// Used to create the Future containing either the file content or an error
val promisedErrorOrContent = Promise[Either[DOMError, String]]
val reader = new FileReader()
reader.readAsText(fileToRead, "UTF-8")
reader.onload = (_: UIEvent) => {
val resultAsString = s"${reader.result}"
promisedErrorOrContent.success(Right(resultAsString))
}
reader.onerror = (_: Event) => promisedErrorOrContent.success(Left(reader.error))
promisedErrorOrContent.future
}