一切皆为 JavaScript
JavaScript起源于Netscape公司的LiveScript语言,这是一种基于对象和事件驱动的client脚本语言。最初的设计是为了检验HTML表单输入的正确性。
早些年,JavaScript因为其复杂的文档对象模型(DOM)、糟糕的实现和调试工具、不一致的浏览器实现而不受开发人员的待见。而随着技术的发展, JavaScript变得越来越的强大、完好。比方, Ajax技术能够创建更加迷人的Web应用,Node.js将JavaScript的应用范围扩展到了server端。各种层出不穷的框架使得JavaScript的开发更加简捷,尤其是近几年HTML5的出现,将 JavaScript提升到了前所未有的高度。
现在 JavaScript已经变成了Web开发必备的语言,甚至開始逐步向移动领域渗透。因为JavaScript的跨平台特性,使得它在移动互联网时代有更大的作为。
凡是能够用 JavaScript 来写的应用,终于都会用 JavaScript 来写。
——Atwood定律(Jeff Atwood在2007年提出)
不会JavaScript怎么办?
现在 JavaScript已经成为了Web开发的“标配”语言,无论你喜不喜欢。在Web开发中。必然要涉及到JavaScript。JavaScript能够实现真正的“一次编写,到处执行”。并能够控制全部经常使用的浏览器,因此。JavaScript p=298">还被称作“Web的虚拟机”以及“Web上的汇编语言”
虽然如此。可是假设你还没開始学习JavaScript,这也不影响你编写Web应用。你全然能够用你喜欢的语言(Java、.NET、C/C++、Python、Ruby……)来编写应用程序,然后将它们编译为JavaScript语言。然后再执行于浏览器上。
假设你对JavaScript的语法不惬意,你也能够使用一些JavaScript的增强版语言。
比方。假设你更喜欢经典的面向对象方式,并想要一些语法糖,那么你能够试试CoffeeScript;假设你希望有一个更严格的类型系统,那么你可能会发现Dart或TypeScript更有趣一些;假设你更喜欢函数式编程。那么ClojureScript或Roy能够帮助你。
将你擅长的语言编译为JavaScript
将Java代码编译为JavaScript
虽然JavaScript名字中包括“Java”。实际上JavaScript和Java没有不论什么关系,仅仅是因为当时Java火得一塌糊涂,为了借助Java的名气来推广,就起名为JavaScript了。
各种强大的工具的出现,使得JavaScript代码和Java代码之间有了一定的联系,就是能够将Java代码编译为JavaScript代码,以便在浏览器中执行。当然,除了Java外。其它基于JVM的语言都能够如此做。
能够实现此类操作的工具例如以下。
- BicaVM:一个使用JavaScript实现的JVM,能够执行60%的Java字节码
- Ceylon:一个可编译为JavaScript的、模块化的、静态类型JVM语言
- Doppio:一个使用Coffeescript实现的JVM,使得Java程序能够执行在不论什么JavaScript引擎上
- GrooScript:一个能够将Groovy代码转为JavaScript代码的小框架
- j2js:能够将Java字节码转换为JavaScript代码
- Java2Script:Eclipse中的Java to JavaScript编译插件,并实现了一个JavaScript版的Eclipse SWT
- Kotlin:能够编译为JVM字节码和JavaScript的静态类型编程语言
- Processing:一个基于Java的可视化语言,能够编译为JavaScript
- STJS:Strongly-Typed JavaScript(强类型的JavaScript)。一个能够将Java源代码转换为JavaScript代码的Maven插件
将C/C++代码编译为JavaScript
C/C++现在也能够用来编写Web应用程序,相同能够将它们编译为JavaScript。一些工具例如以下。
- Emscripten:Mozilla开发的LLVM后端,能够将不论什么通过LLVM前端(比方C/C++ Clang)生成的LLVMIR中间码编译成JavaScript代码。
- mala:能够将vala代码(vala代码在编译时,首先会编译为C代码)编译为JavaScript
- Mandreel:能够将C++和Objective-C代码编译为高度优化的JavaScript源代码
- Clue:一个C语言编译器,能够将C语言代码编译为高质量的Lua、Javascript或Perl代码。
因为Emscripten能够将LLVM二进制代码编译成JavaScript。LLVM是一种非常流行的中间编译格式,差点儿全部语言都有LLVM编译器,因此Emscripten也能够作为大部分语言转换为JavaScript的通用工具。
将Python代码编译为JavaScript
能够使用例如以下工具将Python代码编译为JavaScript代码。
- Brython:用于替换网页上的JavaScript代码,同意使用Python来编写脚本,并直接在网页上运行
- PYXC-PJ:能够将Python转换为JavaScript,并会产生一个行/列号映射文件
- Pyjaco:能够将Python转换为JavaScript
- Pyjamas:Python to JS转换器
- Pyjs:Python to JS转换器
- PyCow:能够将Python代码转换为 MooToolsJS代码
- PyvaScript:一个类似于Python语法并拥有JavaScript特性的编程语言
- RapydScript:增强版的PyvaScript
- Skulpt:client的Python
将Ruby代码编译为JavaScript
在Ruby领域,有一个使用JavaScript实现的Ruby标准库—— RubyJS,它实现了Ruby中的全部方法,如Array、Numbers、Time等。Ruby之父松本行弘称“假设我必须编写JavaScript代码。我会使用RubyJS”。
另外,你也能够使用例如以下工具将Ruby代码编译为JavaScript代码。
- 8ball:一个能够将Ruby(或Ruby子集)的源代码转换为JavaScript源代码的编译器
- ColdRuby:一个Ruby 1.9 MRI字节码编译器和JS执行时。包含一个C++执行时以及用于本地执行的V8引擎
- HotRuby:能够在浏览器内部或Flash平台上执行由YARV编译的Ruby操作码
- Opal: 一个Ruby to JavaScript编译器,可用于不论什么JS环境
- rb2js:一个Ruby to JavaScript编译器
- Red:同意你以Ruby的方式编写代码。然后以JavaScript的方式执行代码
将.NET代码编译为JavaScript
你能够使用例如以下工具将C#、F#以及其它.NET代码编译为JavaScript代码。
- Apps in Motion:同意使用C#来构建能够执行在不论什么设备上的Web应用程序
- Blade:一个Visual Studio扩展,能够将C#代码转换为JavaScript
- FunScript:可通过TypeScript的类型提供器将F#代码转换为JavaScript或JQuery代码
- jsc:可将.NET程序又一次编译为JavaScript、ActionScript、PHP或Java程序
- JSIL:可将MSIL(.NET字节码)转换为 JavaScript
- NemerleWeb:可将Nemerle语言(微软的多范型语言)编译为JavaScript
- Pit:可将F#代码编译为Javascript
- Prefix(开发中):可将C#代码编译为Javascript
- Saltarelle:可将C#代码编译为Javascript
- SharpKit(商业工具):可将C#代码编译为Javascript
- Script#:可将C#代码编译为Javascript
- WebSharper:可将F#代码编译为Javascript.
将Scala代码编译为JavaScript
你能够使用例如以下工具将Scala代码编译为JavaScript代码。
- Scala.js:一款将Scala编译为JavaScript的编译器。支持所有Scala语言特性,同意开发人员用Scala开发从前端到后端的Web应用
- js-scala:在Scala中将JavaScript作为嵌入式的DSL语言
- Scala+GWT:通过GWT工具链将Scala代码编译为JavaScript语言
将Flash转换为JavaScript
HTML5(HTML/JavaScript/CSS3技术组合)的最大对手就是Flash,虽然眼下Flash的市场份额还高居70%。但也不可否认。未来将是HTML5的天下。
就连Flash的开发商Adobe也開始拥抱HTML5,并公布了Toolkit for CreateJS工具,方便Web开发人员将Flash转换为HTML5格式。
去年,Google曾公布了一套基于网页的的工具——Swiffy。在线就可以将SWF格式的Flash文件转化为HTML5格式。
除了转换外,Mozilla还推出了一个新的解决方式——Shumway,这是一个“基于JavaScript的Flash虚拟机和执行时”,目的是在浏览器中构建一个可靠有效的SWF(Flash文件格式)渲染器,无需插件直接在浏览器中执行Flash。
由此可见。这些工具将进一步加速HTML5代替Flash的步伐。
其它编译工具
编译为JavaScript后的问题
调试问题
因为是交叉编译。导致输出的代码非常难被跟踪调试。
一些工具在编译的过程中会生成映射文件(将编译后的JavaScript代码映射到源语言)。能够通过这些文件来进行调试。
性能问题
因为 JavaScript在浏览器中执行问题,本地代码编译为JavaScript后的执行速度可能会下降。
对于此类问题。Mozilla给出了一个解决方式—— asm.js(见《 asm.js:JavaScript的“汇编语言”》)。asm.js是一个JavaScript的一个严格的子集,提供了一个类似于C/C++虚拟机的抽象实现,包含一个可有效负载和存储的大型二进制堆、整型和浮点运算、高阶函数定义、函数指针等,能够被用来作为一个底层的、高效的编译器目标语言。
此外,还能够使用Mozilla开发的 JavaScript引擎OdinMonkey来获得更快的运行速度。开发人员能够将编写的代码编译为JavaScript,然后手动编写为asm.js代码。当浏览器运行该程序时,OdinMonkey引擎会让程序的运行速度更接近于本地应用。Mozilla未来可能会开发一些工具(类似于LLJS)来自己主动生成asm.js代码。
随着技术的发展,未来JavaScript或许会跑得和native C一样快。
一些演示
2012年。Mozilla曾推出一款Web版的第一人称射击游戏演示BananaBread,今年5月份。Mozilla宣布与Epic Games合作将虚幻引擎3(C/C++实现)移植到浏览器上。并公布了基于虚幻引擎3的HTML5演示游戏Epic
Citadel,这些游戏都是基于WebGL、 Emscripten和高性能的JavaScript子集asm.js实现。又一次定义了3D游戏在浏览器中执行的性能,展示了高端游戏也能够非常easy地移植到JavaScript 和 WebGL平台,同一时候不失性能和画面效果。
Mozilla的还有一款支持多人在线的HTML5 游戏—— BrowserQuest。
随着HTML5新特性Full Screen API、Gamepad API和Mouse Lock API的完好,浏览器或将成为未来游戏的新战场。
增强版的JavaScript
JavaScript大量的扩展,在非常大程度上弥补了JavaScript某些方面特性的不足。比方你能够使用例如以下这些工具或扩展来让JavaScript更强大。
安全性增强
- ADsafe:提供了client静态验证功能和相关的API。增强第三方脚本的安全性
- Caja:能够将传统的HTML和JavaScript转换为安全限制的JavaScpit格式
- Dojo Secure:用于构建安全混搭应用的框架
- FBJS:Facebook的JavaScript工具。用于编写Facebook小插件
- Jacaranda:支持对象的静态验证器
- Gatekeeper:一个JavaScriptpassword保护脚本
- Microsoft Web Sandbox:通过隔离来保证安全性
静态类型特性
- JSX:一个更快、更安全、更易用的JavaScript替代品
- Elm:类型安全的函数式语言,可编译为HTML、CSS和JavaScript.
- Lambdascript:一个强类型的纯函数式原型语言
- MileScript:一个类似于C#和Java的强类型语言,可编译为JS
- SafeJS:为JavaScript添加了语法糖
- Mascara:为JavaScript添加了强大的功能,比方类、命名空间和类型检查等
- Roy:函数式语言。与JavaScript语义保持接近,拥有类型判断、结构类型、sum类型、模式匹配等
JavaScript的衍生品
JavaScript现在在Web开发界的地位无法撼动,可是仍不断有一些新的语言出现。希望可以通过提供更强大、更完好、更优雅的特性来取代JavaScript。
- CoffeeScript: CoffeeScript是一个使用纯Ruby编写的编程语言,仅仅使用了JavaScript的“精髓”,抛弃了原来JavaScript晦涩、easy出问题的部分。如全局变量声明、with等。并提供了非常多语法糖,让代码更优雅可读。
- Dart:Google推出的一种基于类的可选类型化编程语言,能够在原生虚拟机中直接执行,也能够用编译器将Dart代码翻译成 JavaScript代码。
- TypeScript:JavaScript的一个超集,加入了可选的静态类型和基于类的面向对象编程。
- ClojureScript:由Clojure的创建者Rich Hickey推出,目标是“做Javascript所能做到的事情”,代码可编译为Javascript。
- IcedCoffeeScript: Coffeescript语言的扩展集,加入了2个keywordawait和defer。为浏览器和server两者提供了强大的异步控制功能。
- LiveScript:Coco的一个分支。是CoffeeScript的间接子集,并在面向对象和命令式编程方面进行了诸多改进,代码能够编译成JavaScript。
- Kaffeine:JavaScript语法的扩展,与JavaScript非常类似,代码能够直接编译成JavaScript。
很多其它工具可參见: http://altjs.org/
最后
差点儿全部主流的语言都能够编译为JavaScript。进而能够在全部平台上的浏览器中运行,这也体现了JavaScript的强大性和在Web开发中的重要性。此外,互联网中还存在大量的工具,使得这些语言能够与 JavaScript进行互操作,我们将在以后的文章中具体介绍。
以上这些工具中,大部分都是开源项目,假设感兴趣,你也能够通过源代码来了解这些语言之间进行转换的相关原理和技术。
作者:王果 (本文最早于2013年11月发表于CSDN资讯头条)
一切皆为 JavaScript的更多相关文章
- 10大支持移动“触摸操作”的JavaScript框架
摘要:移动开发行业的发展速度让人目不暇接,也在此大势之下,推出移动网站App成为开发者必经之路,如何让触屏设备 更易使用?如何让网站对触摸手势做出反应并使触摸更友好?所有这一切,皆因JavaScrip ...
- 45本免费的JavaScript书籍资源收集
JavaScript目前变得越来越流行,已经变成了Web开发必备的语言,加之其跨平台的特性,使得在一切皆为JavaScript的移动互联网时代大有作为. 同时,我们看到,在过去的这一年的软件开发中,J ...
- JS原生基础终结篇 (帅哥)
闭包 基础 面向对象基础 1.1 闭包 在程序语言中,所谓闭包,是指语法域位于某个特定的区域,具有持续参照(读写)位于该区域内自身范围之外的执行域上的非持久型变量值能力的段落.这些外部执行域的非 ...
- 基于CPS变换的尾递归转换算法
前言 众所周知,递归函数容易爆栈,究其原因,便是函数调用前需要先将参数.运行状态压栈,而递归则会导致函数的多次无返回调用,参数.状态积压在栈上,最终耗尽栈空间. 一个解决的办法是从算法上解决,把递归算 ...
- 宇宙第一IDE是谁?
更多精彩文章,尽在码农翻身 微服务把我坑了 如何降低程序员的工资? 程序员,你得选准跑路的时间! 两年,我学会了所有的编程语言! 一直CRUD,一直996,我烦透了,我要转型 字节码万岁! 上帝托梦给 ...
- 从0到70%:Chrome上位揭秘!
最近的数据显示,Chrome在2020年4月的市场份额达到了70%左右,把微软的Edge和Firefox远远甩在身后,毫无疑问,Chrome赢得了第二次游览器之战,成为新一代王者. Chrome的第一 ...
- javascript之一切皆为对象3
在前面两个章节“Javascript之一切皆为对象1”和“Javascript之一切皆为对象2”中,曾提到: 1.“一切(引用类型)皆为对象” 2. “每个函数都有一个prototype” 3. “每 ...
- javascript之一切皆为对象2
其实呢,“函数function”和“对象object”之间还有这么一句话:对象是通过函数来创建的,而函数却又是一种对象. 这个函数是一种对象,上节中“Javascript之一切皆为对象1”也清楚的阐述 ...
- Javascript之一切皆为对象1
在javascript的世界里,有这么一句话,一切皆为对象. 但是这个对象,应该怎么理解呢? OMG,难道值类型也是对象?!! 当然,不是. 准确地讲是对于“引用类型”而言. 那,在JavaScrip ...
随机推荐
- 举例android项目中的string.xml出现这个The character reference must end with the ';' delimiter.错误提示的原因及解决办法
今天在一个android项目中的string.xml中写这样一个字符串时出现了下面这个错误提示: The reference to entity "说明" must end wit ...
- c语言利用指针计算字符串的长度
可以用strlen函数,这里我们自己写一个. 注意:不能用scanf,scanf一遇到空格就认为输入结束.应该用gets(),遇到换行符或EOF结束.说明可以接受空格. #include<cst ...
- 1、Zookeeper熟悉和用途综述
集群 配置: 192.168.32.80 192.168.32.81 192.168.32.82 server 1: zjtest7-redis:/opt/zookeeper/conf# cat zo ...
- android 中webview调用js
1.android中利用webview调用网页上的js代码. Android 中可以通过webview来实现和js的交互,在程序中调用js代码,只需要将webview控件的支持js的属性设置为true ...
- Dynamic Pivot table wizard SQL Server
原文 http://www.gyurcit.hu/pivot.html Dynamic Pivot table wizard This stored procedure generate dynami ...
- Debian安装Nexus
前置条件 安装jdk (如果使用 nexus-2.6 以上版本需要jdk7) 1 apt-get install openjdk-6-jre / apt-get install openjdk-6-j ...
- 使用Boost.PropertyTree处理XML、JSON和INI数据
Boost.PropertyTree 应该是 Boost 1.41.0 开始正式加入 Boost 版本的.目前 ( 2010/02/28 ) 能下到的最新版本是 1.42.0. 主要作用/应用场合 B ...
- Maven+Eclipse+Spring MVC简单实例
1. ToolsVersion and Preparations: Eclipse: 3.5 (eclipse-jee-galileo-win32) Maven: 2.0.11 Spring MVC ...
- HTML - HTML Commonly Used Character Entities
HTML Entities Some characters are reserved in HTML. It is not possible to use the less than (<) o ...
- c++ split模板实现
模板实现,重载+6: template<typename _Elem, typename _Fty> inline void split(const _Elem* s, const _El ...