- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 scalajs 0.6.15 与 scalajs-react 0.11.3 和 reactjs 15.4.2 一起使用。
考虑一个组件 SomeComp
,其中 Props
的值类型需要参数化。
由于在使用组件构建器时需要知道类型,所以我将组件包装在一个类中。
class SomeComp[T]() {
case class Props(t: T, onChange: T => Callback)
val component = ReactComponentB[Props]("SomeComp")...
def apply(t: T, onChange:T => Callback) = component(Props(t, onChange))
}
这行得通。问题是,组件会随着父级的每次重新渲染而重新安装,除非 SomeComp
的用户首先创建 SomeComp
的实例并在父级的 中使用该实例>render
方法。
我避免这种情况的 hack 解决方案是:
object SomeComp {
val genericComp = SomeComp[Any]()
def apply[T](t: T, onChange: T => Callback) = genericComp(
t = t,
onChange = (a: Any) => onChange(a.asInstanceOf[T])
)
}
有没有更好的、更少的样板代码、更简单的方法?有什么建议吗?
更新在@Golly 的(谢谢你详尽的回答!)建议之后,我发现第二个解决方案最优雅,为了完整起见,我想把它贴在这里:
object SomeComp {
trait Props{
type T
val t: T
val onChange: T => Callback
}
// use Props#T if you need to reference T
val component = ReactComponentB[Props]("SomeComp")...
def apply[_T](_t: _T, _onChange: _T => Callback) = {
val props = new Props {
type T = _T
val t = _t
val onChange = _onChange
}
component(props)
}
}
最佳答案
多年来,我在多态组件方面进行了几次尝试,但已经放弃了完美。如果我们接受微小的缺陷,那么就会有足够的,甚至是很好的解决方案:
1a) 围绕构建器的类。正是您在第一个示例中所拥有的除了一个重要区别:每种类型只创建一个类。如您所见,为相同类型创建新类会导致卸载/重新安装(因为 React 认为组件不同),就像您做这样的事情一样:
final class SomeComp[A] private[SomeComp] () {
val component = ReactComponentB[Props]("SomeComp")...
}
object SomeComp {
val Int = new SomeComp[Int]
val String = new SomeComp[String]
}
如果您事先不知道类型,也没关系,只需为您的类型创建一次类并将其放入被调用者 的伴生对象中。这是一个小瑕疵,您需要为每种类型创建一个单例,但一切其他都保持简单。
1b) 与上面类似,除了使用函数而不是类。为每个类型(可选地为每个被调用者)创建一次并重复使用。
2) 我不推荐这样做,但你可以使用存在类型而不是通用类型,特别是使类型参数成为类型成员。
class Props {
type T
val value: T
val onChange: T => Callback
}
现在组件是单态的,但您需要一些样板文件来很好地创建和使用 Props 类。
顺便说一句,如果您自己创建一个 (T x T → Callback),您可以使用一个内置的回调:https://github.com/japgolly/scalajs-react/blob/master/doc/EXTRA.md#statesnapshot (doc 是针对 1.0.0-RC1+ 的,在 pre-1.0 days 中曾经是两个类:{Reusable,Exeternal}Var)
关于scala - 如何在 scalajs-react 中使用类型参数化组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43559344/
如何使用 sbt-scalajs 插件排除 scalajs 依赖? 我正在尝试导入以下库 "org.webjars.bower" % "react-bootstrap-datetimepicker"
这些 Scala.js React.js 库之间有什么区别,我为什么要选择一个而不是另一个? Xored Scalajs-react - 最后一次提交是 8 个月前。所以我猜测开发不再活跃。 Scal
来自 Scala.js 的 sbt fastOptJS ,我只想重定向 myproject/target/scala-2.11/web-fastopt.js至myproject/js这可能吗? 同样适
在使用 ScalaJS 时,我可以像这样导出一个对象和所有成员 @JSExport object Thing { @JSExport def doThing(x:Int) = x * 2 }
好吧,它不是字面意义上的“Hello World!”程序,但等效:它使用 WebGL 渲染上下文将几个三角形输出到 Canvas 。 该程序按其应有的方式工作,但是有什么方法可以摆脱程序后半部分中那些
scala.js 是否与 scala ZIO 一起使用? 我想在 scala.js 中使用 scala ZIO 我只知道如何在普通应用程序中使用 scala ZIO 有谁知道如何在 scala.js
是否可以在浏览器中运行生成的js测试代码? ScalaJS 似乎在目标目录下生成以下 js 文件 (project-name)-test-fastopt.js (project-name)-test-
关于 scalajs 和 javascript 的问题。 如何将函数标记为纯粹导出到全局范围? 给定顶级包中的 scala 对象 @JSExport object Foo{ def apply(a:
如果我正确理解 scalajs 文档,它只允许每个项目生成一个 javascript。有没有办法避免这种限制? 目前我为 Play 框架创建了 scalajs 子项目。在这个子项目中,我计划为我正在处
我希望使用 ScalaJ-Http 作为 http 客户端。链接:https://github.com/scalaj/scalaj-http 我将如何模拟 Http或 HttpRequest在具有这样
我将 scalajs 0.6.15 与 scalajs-react 0.11.3 和 reactjs 15.4.2 一起使用。 考虑一个组件 SomeComp,其中 Props 的值类型需要参数化。
我想编写 Scala 代码,然后可以将其转换为 EmberJS 代码。 可以做到吗?如果不是开箱即用的关于如何通过破解 ScalaJS 来实现的任何建议? 问候。 最佳答案 Scala.js 可以发出
我有一个我想从 JS 调用的 ScalaJS 函数,它有一个 Option[String] 参数。我不知道如何从 JS 创建 Some[String] 和 None[String]。 最佳答案 简短的
在下面的代码示例中,当使用 scalatest 测试 Scala 时,如何等待 ajaxCall() 完成才能开始 test 1 .js 代码?我不能在 Scala.js 中使用 await。 cla
我是 Scala.js 的新手。我想使用 Argonaut json 库。 https://github.com/argonaut-io/argonaut 它唯一的依赖项似乎是 Monocle 和 S
(前面的问题很长。简化的tl;底部的博士)。 我有两个使用 SBT 构建的 ScalaJS 项目——“myapp”和“mylib”,位于以下目录结构中 root/build.sbt root/myap
编辑: 截至2013年1月27日的版本信息: Scala 2.10.0 IntelliJ IDEA Leda 123.139 (EAP) Scala Plugin version 0.7.108 (N
尝试获取Ajax.post失败的原因(使用Scala.Js),但仅获取类名称: Ajax.post( url = "...", data = "...", headers = Map("C
我有一个跨项目 Scala/ScalaJS。当我在客户端模块中运行测试时,出现以下异常: IJ]sbt:pme123-adapters-client> testOnly ... [info] Fast
我找到了 scalaj-collections它看起来是唯一可以让我将 Java.util.List 转换为 scala.collection.Seq 的库。 我可以在我的 Java 项目中使用这个库
我是一名优秀的程序员,十分优秀!