Der Titel wird wie folgt umgeschrieben: „Integration von serverseitigem Rendering mit Scalajs-React' wird ins Chinesische übersetzt als „Integration von Scalajs-React mit Server-Side-Rendering'.
P粉155551728
P粉155551728 2023-08-30 10:58:29
0
1
560
<p>Ich habe versucht, der Anleitung zur Integration von serverseitigem Rendering in Scalajs-React zu folgen, aber mein Stack ist möglicherweise etwas anders und daher nicht so intuitiv.</p> <p>我正在使用<code>SBT 1.5.5</code>,<code>scala 2.12.10</code>以及以下相关插件:</p> <pre class="brush:php;toolbar:false;">addSbtPlugin("com.typesafe.play" % "sbt-plugin" % "2.7.4") addSbtPlugin("org.scala-js" % "sbt-scalajs" % "1.7.0") addSbtPlugin("org.scala-js" % "sbt-jsdependencies" % "1.0.2") addSbtPlugin("ch.epfl.scala" % "sbt-scalajs-bundler" % "0.20.0") addSbtPlugin("com.eed3si9n" % "sbt-buildinfo" % "0.10.0") addSbtPlugin("org.scala-native" % "sbt-scala-native" % "0.3.7") addSbtPlugin("org.portable-scala" % "sbt-scalajs-crossproject" % "1.2.0") addSbtPlugin("org.portable-scala" % "sbt-scala-native-crossproject" % "1.2.0")</pre> <p>在文章的<strong>第2步</strong>中,它说要将以下内容添加到'build.sbt'文件中:</p> <pre class="brush:php;toolbar:false;">val scalaGraalVer = "1.0.1" lazy val webappSsr = crossProject("webapp-ssr") lazy val webappSsrJs = webappSsr.js .dependsOn(myScalaJsWebapp) // 将此处更改为您真正的SJS模块名称 .Einstellungen( Bibliotheksabhängigkeiten ++= Seq( „com.github.japgolly.scala-graal“ %%% "core-js" % scalaGraalVer, „com.github.japgolly.scala-graal“ %%% "ext-boopickle" % scalaGraalVer ), scalaJSLinkerConfig ~= { _.withSourceMap(false) }, artefaktPath in (Compile, fastOptJS) := (crossTarget.value / "webapp-ssr.js"), artefaktPath in (Compile, fullOptJS) := (crossTarget.value / "webapp-ssr.js") ) lazy val webappSsrJvm = webappSsr.jvm .Einstellungen( Bibliotheksabhängigkeiten ++= Seq( „com.github.japgolly.scala-graal“ %% "Kern" % scalaGraalVer, „com.github.japgolly.scala-graal“ %% "core-js" % scalaGraalVer, „com.github.japgolly.scala-graal“ %% "ext-boopickle" % scalaGraalVer ), unmanagedResources in Compile += Def.taskDyn { val stage = (scalaJSStage in Compile in webappSsrJs).value val task = stageKey(stage) Def.task((Aufgabe in Compile in webappSsrJs).value.data) }.Wert) )</pre> <p>所以我目前在这里有2个问题:</p> <ol> <li><p><code>crossProject</code>似乎不接受<code>String</code>作为参数,即:</p> <p><code>def crossProject(平台:sbtcrossproject.Platform*)</code></p> </li> <li><p>在<code>val task = stageKey(stage)</code>处 - <code>stageKey</code>无法弄清楚它的位置,因此不知道我缺少什么或是否有其他方法.</p> </li> </ol></p>
P粉155551728
P粉155551728

Antworte allen(1)
P粉378890106

就像@tdimoff已经说过的那样,sbtcrossproject库的crossProject方法不接受字符串参数,所以这行代码lazy val webappSsr = crossProject("webapp-ssr")应该替换为lazy val webappSsr = crossProject(JSPlatform, JVMPlatform)

关于stageKey函数,它似乎是scalajs-bundler库的一部分,所以您需要添加以下库依赖:

libraryDependencies += "ch.epfl.scala" % "scalajs-bundler" % "0.20.0"

这样应该可以使用stageKey函数。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage