サーチ…


前書き

Scala.jsは、 JavaScriptにコンパイルされたScalaポートで、最後はJVM外で実行されます。強力な型付け、コンパイル時のコード最適化、JavaScriptライブラリとの完全な相互運用性などの利点があります。

Scala.jsのconsole.log

println("Hello Scala.js") // In ES6: console.log("Hello Scala.js");

脂肪の矢印機能

val lastNames = people.map(p => p.lastName)
// Or shorter:
val lastNames = people.map(_.lastName)

シンプルクラス

class Person(val firstName: String, val lastName: String) {
  def fullName(): String =
    s"$firstName $lastName"
}

コレクション

val personMap = Map(
  10 -> new Person("Roger", "Moore"),
  20 -> new Person("James", "Bond")
)
val names = for {
  (key, person) <- personMap
  if key > 15
} yield s"$key = ${person.firstName}"

DOMの操作

import org.scalajs.dom
import dom.document

def appendP(target: dom.Node, text: String) = {
  val pNode = document.createElement("p")
  val textNode = document.createTextNode(text)
  pNode.appendChild(textNode)
  target.appendChild(pNode)
}

SBTで使用する

Sbt依存

libraryDependencies += "org.scala-js" %%% "scalajs-dom" % "0.9.1" // (Triple %%%)

ランニング

sbt run

コンパイルを継続して実行する:

sbt ~run

単一のJavaScriptファイルにコンパイルする:

sbt fastOptJS


Modified text is an extract of the original Stack Overflow Documentation
ライセンスを受けた CC BY-SA 3.0
所属していない Stack Overflow