Google Dart抗衡JavaScript的十大亮点

导读: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或许会在另一面成为主流。
 

你可能感兴趣的:(程序员,编程语言,Google,排行榜,一见钟情)