如何将Javascript类转换为ScalaJS

如何解决如何将Javascript类转换为ScalaJS

我有这个简单的Javascript代码

import Modeler from 'bpmn-js/lib/Modeler';

import diagramXML from './diagram.bpmn';

const modeler = new Modeler({
  container: '#canvas'
});

modeler.importXML(diagramXML);

在浏览器中打开时会显示一个图。

我想在 ScalaJS 中执行此操作,但是我错过了一些事情。

这是我的代码

@JSImport("resources/diagram.bpmn",JSImport.Default)
@js.native
object DiagramXML extends js.Object

object Main {

  @JSExportTopLevel("main")
  def main(): Unit = {
    val modeler = new Modeler(js.Object(
      "container" -> "#canvas"
    ))

   modeler.importXML(DiagramXML.toString)
 }
}

这是我Modeler的门面:

@js.native
@JSImport("bpmn-js/lib/Modeler","Modeler")
class Bpmnjs(options: js.Object) extends js.Object {

  def importXML(xml: String): js.Promise[Any] = js.native

}

当我调试时,xml已正确加载。唯一缺少的是它已在DOM中正确呈现。

解决方法

我可以在您的翻译中找出两个问题。第一个是import中的bpmn-js。 JS导入为

import Modeler from 'bpmn-js/lib/Modeler';

应翻译为

@JSImport("bpmn-js/lib/Modeler",JSImport.Default)

根据the documentation on translating import into @JSImport

另一个问题更加微妙。在调用new Modeler时,您已经

js.Object(
  "container" -> "#canvas"
)

(可能很不幸)可以编译,但没有执行您认为的操作。它会创建两个字符串的Scala元组,然后将其传递给JavaScript函数Object(...),该函数实际上将按原样返回它(因为Scala元组已经是一个对象)。

您想要的是一个带有字段container的JavaScript对象,您可以将其编写为

new js.Object {
  val container = "#canvas"
}

一种更好的方法是使选项对象在外观中静态键入:

class BpmnJS(options: BpmnJSOptions) extends js.Object {
  ..
}

trait BpmnJSOptions extends js.Object {
  var container: js.UndefOr[String] = js.undefined
}

这样,您可以将其命名为

new BpmnJS(new BpmnJSOptions {
  container = "#canvas"
})

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?