Google Dart抗衡JavaScript的十大亮点

Johnny21 等级 264 0 0

【IT168 技术】导读:Google是家充满创新力的公司。他们不喜欢Javascript了,于是自己推出了Dart。不负众望,Dart在今年的编程语言排行榜中成了一匹黑马,一经发布便窜到了排行榜107位,次月居然到了63,速度惊人。

根据原文编译的内容如下:

Dart是Google推出的新的结构化Web编程语言。我对它一见钟情。有人对我说,你需要深度剖析JavaScript,否则你无权评论它的优缺点。坦诚的说,我算不上一位JavaScript Ninja,但我坚信一种语言应该简单易学,容易理解,语言结构方面尽量合理。

一直以来,我都在实践中解决JavaScript的不足之处,我也承认JavaScript有很多不错的功能。但我不得不说,每天与它工作时我得非常非常小心。这一点很是糟糕,编程语言应该得到程序员的友好支持,而非相反。

下面是JavaScript的不足之处,这也是迫使我转投Dart的原因。

1. Dart uses only one falsify (Dart只使用一种否定条件)

看到这个标题,会容易想到false, null, undefined, “”, 0, NaN 作为否定条件,你可以这样写:

var a = null; if(!a) { // do
}

在Dart只有唯一的false,可以写成这样:

var a = null; if(a != null) { // do
}

虽然可以使用情形6中的否定条件,前提是你要好好了解它们。

2. Dart can work with types, If you want it(只要你想,Dart可以使用类型)

JavaScript开发者常说types(类型)会抹杀了灵活性,或许这是真的,但是太多的灵活性会毁掉你的软件。另一方面,Dart可以很好的用types编程。

3. You need a framework to work proper with DOM (你需要一个框架来解析DOM)

在JavaScript中,你可以这样写:

getElementsById()  
getElementsByTagName()  
getElementsByName()  
getElementsByClassName()  
querySelector()  
querySelectorAll()  
document.links  
document.images  
document.forms  
document.scripts  
formElement.elements  
selectElement.options

这样不是很完美吗?使用jQuery来帮助我们。也并不是非要从选择框架来解析DOM。

但Dart有了jQuery,只需以下2点:

elem.query('#foo');  
elem.queryAll('.foo');

4. Classes and Interfaces (类和接口)

当Java开发人员使用JavaScript时,他们经常尝试着去编写代码,就像编写Java代码一样。有构造函数和类等元素。当然,这不是JavaScript的编程方式。它是基于以一切项目为标准。

5. Inheritance(继承)

Rauschmayer博士发表过一篇优秀的博文,他在博客中解释了为什么JavaScript inheritance很简单。但值得注意的是:他的建议不是JavaScript inheritance的唯一途径。Frameworks Prototype和jQuery创建了“扩展”方法。Rauschmayer博士使用__proto__,你可以使用prototype keyword ,当然,你也可以实现自己的扩展机制,简单复制每个属性。用Google搜索“javascript object extends”弹出的所有结果,有各种各样的方法,只为实现一个目标:扩展。

Dart里有classes概念和“extends”关键词,非常简单。

6. Global namespace (全域名空间)

在JavaScript中你需要注意,不要搅乱全域名空间,老实说,这个很容易。如果错过了“this”或“var”变量,导致每个脚本都能访问它,这是非常可怕的,尽量别搞乱这些。这里要感谢Stoyan Stefanovs Book JavaScript Patterns使我认识到保持域名空间清洁的重要性。现在我感觉好多了,同时也易于控制。

在Dart里扩展了“library”范围,意味着你有一个关键的“library”仅对外开放的部分。此外,每一个Dart脚本能独立执行,有一个活动区域。使用Dart你还应该思考visibility和libraries,这将成为你学会Dart的一种简易方式,,而不需要从其他书籍中获知。

7. Dart knows concurrency (Dart支持并行)

使用JavaScript不是真的并行,即使是但也需要你做出一个“jQuery异步需求”,你依然在“thread”中运行,你可以从V8中获得更多,你也可以通过HTML5和webworkers来解决。

Dart支持Isolates,这有点像Erlang,它们之间可以相互沟通,如果其中一个失败了,另一个Isolate可以再次启动。当然这使Dart成为一个非常不错的服务端编程。

8. JavaScript doesn’t know foreach (JavaScript不支持foreach)

你可以扩展Object或者Array.prototype,或者也可以采用以下数组:

for (var i = 0; i < elements.length; i++) { // do something
}

你还可以设置objects:

for (key in elements) {
  alert(elements\[key\]);
}

       而不幸的是Douglas Crockford(在JavaScript界一位很了不起的人物),不建议使用此语句。原因:你的结果不是排序的,我可能会从prototype chain或者function names命名。当然你也可以过滤hasOwnProperty。最后,你应该看下框架文件,如果他们提供了相应内容。

而在Dart中:

for (element in elements) { // do something
}

就是这么简单!

9. Weirdness intializing arrays(数组初始化)

看看这个代码:

var a1 = new Array(1,2,3,4,5); var a2 = new Array(5);

a1有5个元素的数组:[1,2,3,4,5]

a2具有5个元素的数组:[undefined,undefined,undefined,undefined,undefined]

而Dart就更加简洁:

List a1 = [1,2,3,4,5];
List a2 = new List(5);

同样的,a1包含5个不同的元素数组,a2包含5个元素数组。此外,你还可以获得一个不错的功能“removeRange”可支持排序。

10. undefined和null

当使用JavaScript时你需要学习很多,该类型值:undefined。它可被重写。你可以通过各种方案获得,例如:假如你调用返回,但不返回任何数值,在链接的页面上,你可以看到如何处理一个可能被覆盖未定义的值。Null可以通过undefined在多种方案下调用。

而Dart只需要一个null。

结束语:

当然,JavaScript也有很多好的部分,比如一些不错的模式,但目前来说,使用Dart也能实现这些功能。我认为Dart更优雅,更容易阅读。或许,JavaScript的一些铁杆开发者不这么认为,没关系,只要喜欢你可以继续使用JavaScript。但我想,Dart或许会在另一面成为主流。

收藏
评论区