从GWT开发人员的角度概述Scala.js

该博客严重偏向于GWT(和基于GWT的框架),但是我们牢记未来GWT可能会被其他技术所取代,因此我们始终愿意探索其他平台/框架。 正如他们所说,多元化可以降低风险。 每种编程语言,甚至最奇怪的编程语言,都有其“到javascript”编译器: https : //github.com/jashkenas/coffeescript/wiki/List-of-languages-that-c​​ompile-to-JS ,因此GWT可以尝试学习向他人学习,以便日后改善。 Scala.js一直被与GWT进行比较,因为它们都使用基于JVM的语言,这暗示着语法和语义上的某些相似之处。 Scala.js是Scala到javascript编译器,其工作方式与GWT类似。 Scala.js具有使GWT变得有吸引力的功能的等效项,例如JsInterop,开发模式,修剪,草稿编译,基本等。 我们计划在即将发布的一篇文章中与GWT进行Scala.js比较,但是在此之前,我们想简要介绍一下Scala.js,以及如何编写一个简单的程序。

这是Scala,不是Java

Scala是一种面向对象的JVM语言,它针对功能性编程及其内置的不变性已经引起了一些炒作。 就我个人而言,我从未在Scala中编写任何“实际”应用程序,因此我真的不了解该语言的所有来龙去脉。 似乎您可以使用Scala进行任何操作,也可以使用Java 8进行操作,反之亦然。 在检查语法差异时引起注意的一件事是,Scala具有动态类型推断,因此未声明变量的类型。 这可能看起来更类似于javascript,并且可能会给人一种我们直接使用javascript进行编程的感觉。 Scala.js文档提供了Scala与Es6之间的比较: https ://www.scala-js.org/doc/sjs-for-js/es6-to-scala-part1.html

项目设置

初始设置非常简单。 只有一个用于scala( sbt )的构建工具,一个用于Scala.js的插件,因此没有任何问题。 一个Scala.js项目不需要任何特殊的结构,一个简单的项目结构就足够了。 NodeJs是使用Scala.js的要求。 然后,可以通过运行以下命令来初始化项目:

sbt new scala/scala-seed.g8

从命令行。 然后将提示您输入项目的名称,版本和组织名称(与Maven中的groupId等效)。 然后,我们需要将Scala.js依赖关系和配置添加到我们的build.sbt文件(相当于pom.xml)中。 我们的build.sbt文件看起来像:

enablePlugins(ScalaJSPlugin)name := "scalajsdemo"version := "0.1-SNAPSHOT"scalaVersion := "2.11.8"libraryDependencies ++= Seq("org.scala-js" %%% "scalajs-dom" % "0.9.1"
)scalaJSUseMainModuleInitializer := true

该配置是最小的,因此不需要很大的努力。

使用框架

设置项目后,我们要做的就是创建一个扩展JSApp对象的入口点类。

object MyForm extends JSApp {override def main(): Unit = {}
}
    1. 与DOM交互:
      Scala.js具有非常全面的API,以与原始JS相同的方式进行DOM交互和操作。 实际上,这是Scala.js的核心焦点:默认情况下,没有自定义ui组件来构建ui。 例如,使用事件侦听器创建按钮的代码如下:
      val button = document.createElement("button")button.textContent = "Click button"button.addEventListener("click", { (e0: dom.Event) =>println("clicked")}, false)document.body.appendChild(button)

      为了使用XmlHttpRequest执行HTTP请求,代码如下所示:

      val req = new XMLHttpRequest()req.open("GET", "http://www.g-widgets.com/feed/")req.setRequestHeader("Access-Control-Allow-Origin", "*")

      假设我们要解析G-Widgets Rss feed并创建一个包含所有标题的列表,然后我们将执行以下操作:

      val blogPostsListElement = document.createElement("ul")req.onload = {(e: Event) =>if (req.status == 200) {val parser = new DOMParser();val doc = parser.parseFromString(req.responseText, "application/xml")val titleList = doc.getElementsByTagName("title")for(i <- 0 to titleList.length){val listElement = document.createElement("li")if(titleList.item(i) != null){listElement.textContent = titleList.item(i).textContentblogPostsListElement.appendChild(listElement)}}}}req.send();document.body.appendChild(blogPostsListElement)
  1. 到/从Javascript导出(等效于JsInterop):
    Scala.js还可以使用注释将类导出/导入到Javascript。 假设我们要在代码中使用JSON实用程序对象,导入它的一种方法是:
    @js.native
    @JSGlobal
    object JSON extends js.Object {def parse(data: String): js.Object = js.nativedef stringify(anobject :js.Object): String = js.native
    }

    同样,我们可以使用注释从JavaScript脚本中导出一些要使用的对象:

    @JSExportTopLevel("DummyJs")
    class DummyJs(val dummyValue: String) {@JSExportdef getTheDummyValue(): String = dummyValue
    }

编译和开发模式

关于Scala.js的一件真正整洁的事情是它的编译时间短。 更改代码后,重新编译.js所需的编译时间不会超过9(对于这个简单的应用程序),这非常令人鼓舞,并且减少了挫败感。 Web服务器的选择(如果需要)保持打开状态。 例如,带有实时重载扩展名的服务器可能会派上用场。 Scala.js提供了两种编译模式:fastOptJS和fullOptJS。 当运行fastOptJS(相当于GWT中的草稿模式)时,编译器进行的优化较少,因此编译时间较短。 这是发展的理想选择。 另一方面,fullOptJS使用Google的闭包编译器来生成高度紧凑和优化的.js文件。

包起来

这是对Scala.js的自以为是的介绍。 Scala.js可以提供的主要优点是没有样板的项目设置和快速的编译时间。 GWT比Scala.js更成熟并且使用更多,但是GWT可以从Scala.js中学习,可以减少编译时间和设置项目的样板。 另一方面,一些Scala.js倡导者并不了解GWT的演变,有时会对GWT能力进行不正确的评估。 例如, 格雷格·多雷尔 ( Greg Dorell)在最近的Devoxx 演讲中指出,“ GWT不起作用”,因为它无法为js功能提供良好的导入/导出功能。 他显然忽略了GWT还引入了JsInterop。 GWT仍然在生态系统和社区方面取胜。 我们将在以后的帖子中进行更详细的比较。 综上所述,Scala.Js是开发Web应用程序的一种有吸引力的替代方法。 对于Java开发人员来说,可能存在语言障碍,但是学习曲线不会真的很陡峭,因为Java和Scala都是JVM语言并且具有相似的概念。

完整的代码可以在这里找到: https : //github.com/zak905/scalajsdemo

翻译自: https://www.javacodegeeks.com/2017/07/overview-scala-js-gwt-developer-perspective.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/349023.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

alinq mysql_ALinq让Mysql变得如此简单_MySQL

当大家已经习惯了使用.net 去操作SQL Server&#xff0c;有多少人曾经尝试过使用.net 去操作Mysql数据库&#xff01;在.net 的光环下&#xff0c;Mysql是显得如此微不足道&#xff01;但是Mysql的开源又是如此具有诱惑。1. ADO.NET 方式连接Mysql数据库经过在网上查找资料&…

debian php mysql 安装_在 Debian 下安装 Apache,MySQL,PHP

我是转载过来的&#xff0c;原地址 http://blog.csdn.net/youngdze/article/details/20455557 ,我安装成功!首先&#xff0c;对你的源进行更新&#xff1a;$ sudo apt-get update第一步--安装 ApacheApache 是一个开源软件&#xff0c;它目前运行在全球超过 50% 的服务器上&…

java ee cdi_Java EE CDI bean范围

java ee cdiJava EE平台的上下文和依赖注入&#xff08;CDI&#xff09;是一项功能&#xff0c;有助于将Java EE平台的Web层和事务层绑定在一起。 CDI是一组服务&#xff0c;可以一起使用&#xff0c;使开发人员可以轻松地在Web应用程序中使用企业bean和JavaServer Faces技术。…

airflow mysql_Airflow 使用及原理分析

Airflow 入门及使用什么是 Airflow&#xff1f;Airflow 是一个使用 Python 语言编写的 Data Pipeline 调度和监控工作流的平台。Airflow 是通过 DAG(Directed acyclic graph 有向无环图)来管理任务流程的任务调度工具&#xff0c;不需要知道业务数据的具体内容&#xff0c;设置…

mysql关于死锁的优化_mysql死锁探究及优化

什么是锁&#xff1f;锁是计算机为了平衡协调多个进程或线程并发访问资源的机制。计算机除了cpu&#xff0c;ram&#xff0c;I/O&#xff0c;数据也是一种共享资源。锁冲突是影响数据库并发性能的一个重要因素。例如行锁&#xff0c;表锁等&#xff0c;读锁&#xff0c;写锁等&…

jdk8 calendar_JDK 8的Calendar.Builder

jdk8 calendar勇敢的Java新世界的定义特征之一是Java空间中构建器模式的日益普及。 Groovy是JVM上最流行的替代语言&#xff08;对于Java&#xff09;&#xff0c;以在核心库以及Groovy支持的库和框架中大量使用Builder而闻名。 Josh Bloch将该模式带到了Java开发人员社区的最前…

mt5 mysql数据库_Django -- 使用MySql数据库

Django默认使用的sqlite3&#xff0c;这在实际的生产环境中是不推荐的&#xff1b;1. 创建数据库Linux VM_0_15_centos 3.10.0-693.el7.x86_64 #1 SMP Tue Aug 22 21:09:27 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux1.1. 使用utf8mb4编码mysql的utf-8编码最多只支持3个字节&…

gradle 安装_如何安装Gradle

gradle 安装Gradle是一个依赖管理/构建工具&#xff0c;结合了Maven和Ant的优点&#xff0c;使其成为功能强大且可自定义的工具。 它还使用了光滑的Groovy DSL而不是Maven和Ant的XML方法&#xff0c;并且当我开始一个新项目时&#xff0c;它是我个人的选择工具。 安装方法如下。…

wps怎么旋转页面_用WPS文字编辑一份试卷,详细教程来了,老师们赶快收藏吧

​ 试卷是每一个教师接触最多的资料了&#xff0c;很多教师在检测前找一些现成的试卷复印给学生练习&#xff0c;但是&#xff0c;有很多题不适合学生&#xff0c;因此&#xff0c;我们需要自己编辑一份试卷了&#xff0c;编辑试卷也并不是很难的&#xff0c;今天&#xff0c;就…

maven 部署nexus_Maven部署到Nexus

maven 部署nexus1.概述 在上一篇文章中 &#xff0c;我讨论了Maven项目如何在本地安装尚未部署在Maven Central&#xff08;或任何其他大型且公共托管的存储库&#xff09;上的第三方jar。 该解决方案仅适用于小型项目&#xff0c;在这些项目中安装&#xff0c;运行和维护完整的…

mongodb mysql json数据_使用MongoDB与MySQL有很多JSON字段?

所以&#xff0c;直接回答问题…Shall we chose mongodb if half of data is schemaless, and is being stored as JSON if using MySQL?无数存储空间肯定是MongoDB的一个引人注目的理由&#xff0c;但正如您所指出的&#xff0c;将JSON存储在RDBMS中也是相当容易的。 MongoDB…

Java命令行界面(第15部分):Jargo

Jargo在其GitHub主页上定义为“一种减轻程序参数/选项处理的工具”。 当已经存在许多其他命令行处理库时&#xff0c;该页面为另一个命令行处理库提供了基本原理 &#xff0c;该列表的顶部是“因为类型安全性&#xff0c;不变性和可读性很重要”。 Jargo的选项“定义”阶段使用…

mysql 过滤相同数据库_MySQL数据库查询中的重复记录过滤

今天帮别人修改程序&#xff0c;需要分组去最大值。也就是所谓&#xff0c;某一字段有重复字&#xff0c;过滤掉有重复的数据。弄了半天&#xff0c;最后总结一下。首先搞点模拟数据出来create table t2 (id int primary key,gid char,col1 int,col2 int) enginemyisam;insert …

python关于文件的编程题_《Python编程》源代码文件

压缩包 : bbc59749e0028c3f1ab3a1c9a762a6d.rar 列表《Python编程》源代码文件/.gitignore《Python编程》源代码文件/appendix_a/README.md《Python编程》源代码文件/appendix_b/hello_world.py《Python编程》源代码文件/appendix_b/Python3.sublime-build《Python编程》源代码…

java中序列化与反序列化_Java中的序列化

java中序列化与反序列化Java提供了一种称为序列化的机制&#xff0c;以按字节的有序或字节序列的形式持久化Java对象&#xff0c;其中包括对象的数据以及有关对象的类型和存储在对象中的数据类型的信息。 因此&#xff0c;如果我们已序列化了任何对象&#xff0c;则可以使用对象…

Java命令行界面(第3部分):jbock

在本系列中有关使用Java进行命令行分析的前两篇文章中&#xff0c;我介绍了Apache Commons CLI和args4j库。 在本系列的第三篇文章中&#xff0c;我将介绍jbock &#xff0c;它是自我描述的“非常简单的CLI解析器”。 我在Java中进行命令行解析的文章使用了一些示例&#xff0…

java 关闭串口_java – 打开和关闭串行端口

我正在尝试连接到Serial Port …但是一旦我第一次打开串行端口.我不能再打开它,我试着申请.这是我的代码&#xff1a;public static void main(String[] args) {portList CommPortIdentifier.getPortIdentifiers();while (portList.hasMoreElements()) {portId (CommPortIden…

java collection详解_java 7 collection 详解(一)

一、综述java集合框架定义了几个接口&#xff0c;这些接口决定了collection类的基本特性。不同的是&#xff0c;具体类仅仅是提供了标准接口的不同实现&#xff0c;如图&#xff0c;java集合框架接口图从图可知&#xff0c;java集合类的主要是由两个接口派生而出——Collection…

java导出pdf 含图片_java 生成PDF含图片和中文件实现代码

1,所需包 iText.jar iTextAsian.ar(支持中包)2,列子package com.pdf;import java.awt.Color;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.net.MalformedURLException;import javax.naming.spi.DirectoryManager;import com.l…

jsf tree组件_JSF:在传统组件和时尚性能杀手之间进行选择

jsf tree组件这篇博客文章起源于一个大型Web应用程序中的性能问题。 每个人都优化Java代码&#xff0c;但似乎没有人尝试优化JavaScript代码。 奇怪&#xff0c;因为在客户端有很多改进的空间。 我会说&#xff0c;甚至比服务器端还要多。 我们将分析可编辑的JSF标准组件&#…