gwt-2.8.2下载_从GWT开发人员的角度概述Scala.js

gwt-2.8.2下载

该博客严重偏向于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

gwt-2.8.2下载

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

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

相关文章

Linux 命令之 killall 命令-使用进程的名称来杀死一组进程

文章目录介绍语法格式常用选项参数参考示例介绍 killall 命令使用进程的名称来杀死进程&#xff0c;使用此指令可以杀死一组同名进程。我们可以使用kill命令杀死指定进程 PID 的进程&#xff0c;如果要找到我们需要杀死的进程&#xff0c;我们还需要在之前使用 ps 等命令再配合…

python selenium 点击开始按钮_使用Selenium和Python单击一个按钮

I have the following code:Expand allWhen I click on expand all, the whole page loads. How can I do it using WebDriver for Python?解决方案As per the HTML you can use the find_element_by_link_text and invoke click() method as follows :driver.find_element_by…

COLLATE oracle,Sql 中Collate用法

今天查询sqlite的时候需要不区分大小写&#xff0c;查了下文档&#xff0c;需要使用collate nocase.顺便学习下collate的用法。collate在sql中是用来定义排序规则的。排序规则其实就是当比较两个字符串时&#xff0c;根据某种规则来确定哪个比较大&#xff0c;是否相等。各个数…

Linux 命令之 nslookup 命令-查询域名 DNS 信息的工具

文章目录介绍常用选项参考示例介绍 nslookup命令的英文全称为 “query Internet name server interactively ”。nslookup命令主要用来查询域名的DNS信息。在使用nslookup之前&#xff0c;先确保已经安装了它&#xff0c;nslookup属于bind-utils包下一个命令 。 nslookup有两…

jdeps_JDeps入门–分析项目的依赖关系

jdepsJDeps是Java依赖关系分析工具 &#xff0c;这是一个命令行工具&#xff0c;它处理Java字节码&#xff08;意味着.class文件或包含它们的JAR&#xff09;&#xff0c;并分析类之间静态声明的依赖关系。 可以用各种方式过滤结果&#xff0c;并可以将其汇总到包或JAR级别。 J…

extjs5的grid垂直滚动条bug_ExtJS 6.2.1 Classic Grid 滚动条bug解决方案

如果列表同时存在横向滚动条和竖向滚动条&#xff0c;当竖向滚动条滚动到底部时点击横向滚动条&#xff0c;滚动条会自动滚动到顶部此bug未在其他版本发现&#xff0c;参考高版本代码重写类解决此bug&#xff0c;直接上代码&#xff1a;/*** 如果列表同时存在横向滚动条和竖向滚…

禁止linux使用密码ssh,linux centos7服务器使用密钥登录ssh同时禁止root密码登录

这两天在大量的给服务器添加密钥&#xff0c;有的服务器简单绑定下就行了。但是京东云目前就毕竟弱了&#xff0c;得自己手动来。目前京东云的服务器需要自己手动修改配置&#xff0c;才能用密钥登录服务器&#xff0c;不然默认还是root用密码登录。把密钥保存到本地&#xff0…

cloudwatch_将CloudWatch Logs与Cloudhub Mule集成

cloudwatch在此博客中&#xff0c;我将解释如何为您的Mule CloudHub应用程序启用AWS Cloudwatch日志 。 AWS提供了Cloudwatch Logs Services&#xff0c;以便您可以更好地管理日志。 它比松散便宜。 由于cloudhub会自动翻转超过100 MB的日志&#xff0c;因此我们需要一种机制来…

linux 权限 mask,【自学Linux】Linux用户、组、权限(一)

用户、组、权限权限&#xff1a;r,w,x文件:r:可读&#xff0c;可以使用类似cat等命令查看文件内容w:可写&#xff0c;可以编辑或删除此文件x:可执行&#xff0c;eXacutable&#xff0c;可以命令提示符下当中命令提交给内核运行0 000 ---&#xff1a;无权限1 001 --x&#xff1a…

要多大内存才满足_什么是延迟满足能力?“延迟满足”能力对孩子有多重要家长要清楚...

文丨饭饭妈记得去年过春节的时候&#xff0c;家里来了两个亲戚&#xff0c;他们分别有一个小孩&#xff0c;当时大家都在准备年夜饭。其中一份糯米团子准备好放在桌子上之后&#xff0c;亲戚家的两个小孩都非常想要吃&#xff0c;亲戚对孩子说&#xff1a;“你们现在不能吃&…

Linux 命令之 cd 命令-切换目录

文章目录介绍语法格式常用选项参考示例介绍 cd 命令是 change directory 中单词的首字母缩写&#xff0c;其英文释义是改变目录&#xff0c;所以该命令的功能是从当前目录切换到指定目录。 其中目录的路径可分为绝对路径和相对路径。若目录名称省略&#xff0c;则切换至使用者…

Linux 命令之 pgrep -- 用于检索(搜索进程/查找进程)当前正在运行的进程

文章目录命令介绍常用选项参考示例示例 1&#xff0c;查看所有名称为 httpd 的进程示例 2&#xff0c;查看进程号最小的&#xff0c;名称为 httpd 的进程示例 3&#xff0c;查看进程号最大的&#xff0c;名称为 httpd 的进程命令介绍 pgrep 的意思是"进程号全局正则匹配输…

java端到端_Java应用程序性能监控:复杂分布式应用程序的端到端性能

java端到端通过从您的应用程序学习企业APM产品&#xff0c;发现更快&#xff0c;更有效的性能监控。 参加AppDynamics APM导览&#xff01; 在最复杂和分布式环境中端到端监视Java应用程序性能-专注于业务事务。 自动发现的业务交易&#xff0c;动态基准&#xff0c;代码级诊断…

Linux内核链表访问链表头指针,linux内核——链表结构分析

http://blog.csdn.net/tigerjibo/article/details/8299584简单整理(使用linux3.0内核)这里首先学习的是内核中一种抽象定义的双向链表&#xff0c;为了提高其扩展性。内核中链表的描述数据结构位置&#xff1a;Types.h (linux-3.0.12\include\linux) 5444 2011/11/2922…

遗传算法求二元函数极值怎么编码_用遗传算法求复杂函数的极值点

确定遗传在元素个体&#xff0c;遗传得到的个体和变异个体中选取最好的30个个体(对应的函数值最大的30个个体)作为下一次迭代的父样本。from random import randintfrom numpy import sindef decode(g):return [((g&0xfff) - 2048) * 0.001, ((g>>12) - 2048) * 0.00…

Linux 命令之 ulimit 命令-控制shell程序的资源

文章目录介绍常用选项参考示例介绍 用来限制系统用户对 shell 资源的访问。如果不懂什么意思&#xff0c;下面一段内容可以帮助你理解&#xff1a; 假设有这样一种情况&#xff0c;当一台 Linux 主机上同时登陆了 10 个人&#xff0c;在系统资源无限制的情况下&#xff0c;这…

java jvm虚拟机_Java虚拟机(JVM)简介

java jvm虚拟机什么是JVM Java虚拟机&#xff08;JVM&#xff09;是使计算机能够运行Java程序的抽象计算机。 JVM有三个概念&#xff1a; 1.规格 2.实施 3.实例。 该规范是正式描述JVM实现要求的文档。 具有单一规范可确保所有实现都可互操作。 JVM实现是满足JVM规范要求的…

linux qt应用程序全屏,QT在ubuntu下实现界面全屏,侧边栏隐藏,上边栏隐藏【实例】...

最近做一个Qt项目(ubuntu 14.04)&#xff0c;需要将界面全屏&#xff0c;全屏之后&#xff0c;ubuntu侧边栏隐藏&#xff0c;上边栏也隐藏&#xff0c;只显示Qt的界面。那么先介绍几个函数&#xff1a;Qt全屏显示函数&#xff1a;showFullScreen()Qt最大化显示函数&#xff1a;…

copyof java_JDK10——copyOf方法

package com.common.learn;import java.util.ArrayList;import java.util.HashMap;import java.util.HashSet;import java.util.List;import java.util.Map;import java.util.Set;/*** author 30378** JDK10中新增73个新功能API类库* 在java.util.List java.util.Set java.util…

Linux 命令之 w 命令-显示目前登入系统的用户信息

文章目录介绍常用选项参考示例显示目前登入系统的用户信息不打印头信息显示用户从哪登录使用短输出格式介绍 w 命令用于显示已经登陆系统的用户列表&#xff0c;并显示用户正在执行的指令。执行这个命令可得知目前登入系统的用户有那些人&#xff0c;以及他们正在执行的程序。…