当前位置:首页 > 开发 > Web前端 > JavaScript > 正文

Dart 比 JavaScript 更酷的10个理由

发表于: 2014-08-28   作者:agevs   来源:转载   浏览次数:
摘要: Dart 是 Google发明的一种新的编程语言。在使用JavaScript一年多以后,我对Dart可谓是一见钟情。我以前是做Java的,我在用JS的时候要学习很多新东西。有人说你必须深入研究JavaScript,否则你没有资格评论它。我不是JS高手,但是我坚信一门编程语言应该易于学习,易于理解,并且语言结构要合理。虽然我也长时间和JS打交道,虽然我也知道JS有很多酷的功能,但是我还是每天得小心翼

Dart 是 Google发明的一种新的编程语言。在使用JavaScript一年多以后,我对Dart可谓是一见钟情。我以前是做Java的,我在用JS的时候要学习很多新东西。

有人说你必须深入研究JavaScript,否则你没有资格评论它。我不是JS高手,但是我坚信一门编程语言应该易于学习,易于理解,并且语言结构要合理。虽然我也长时间和JS打交道,虽然我也知道JS有很多酷的功能,但是我还是每天得小心翼翼的处理JS的问题。这就很不好,编程语言应该对程序员友好,而不是程序员去伺候一门语言。

下面我将列出Dart比JavaScript强的地方,也是吸引我转移到Dart的原因。前端框架分享

1. Dart只有一种否定条件 
在JS中,你可以用 false, null, undefined,"",0,NaN 作为否定条件,例如:

1 var a = null;
2 if(!a) {
3    // do
4 }

在Dart中,只有 false 才是否定条件,上面的代码必须写成这样:

1 var a = null;
2 if(a != null) {
3    // do
4 }


虽然多种否定条件也没有问题,但是明显程序变的复杂和难以阅读,而且你需要学习各种否定条件。

2. Dart可以使用类型 
JS开发者往往强调,类型会降低灵活性。OK,也许是对的。但是过多的灵活性会让你的软件崩溃。有时候,你需要用到类型,在Dart中,这就可以实现,你可以启用类型检查。 前端框架分享 

3. JS需要一个框架来解析DOM 
看看JS的这些方法吧:

01 getElementsById()
02 getElementsByTagName()
03 getElementsByName()
04 getElementsByClassName()
05 querySelector()
06 querySelectorAll()
07 document.links
08 document.images
09 document.forms
10 document.scripts
11 formElement.elements
12 selectElement.options

强大吗?但是我们有JQuery,Dart学习了JQuery,只有两个方法:

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

4. 类和接口 
当Java开发者刚开始写JS的时候,他们总是把JS写的跟Java一样。他们会写类和构造函数,很显然,JS不是这么玩的。在JS中,任何东西都是对象,这看起来很酷,但是那些设计模式就没有用了。取而代之的是JavaScript的设计模式。但这给开发者造成了很多困惑,也让代码一团糟。

5. 继承 
用JavaScript有很多方式实现继承,例如 Dr. Rauschmayer 博客(http://www.2ality.com/2011/11/javascript-classes.html)中讲的那样。或者你也可以用Prototype和jQuery框架,或者你也可以自己实现一套继承的机制。这样就很混乱,为了实现继承这个目标,JS有很多不同的做法,让人头疼。

Dart有类这个概念,所以也就有“extends”这个关键词。一切都很简单!

6. 全局名字空间 
在JS中,如果你有什么变量在全局级别的话,所有的脚本都可以访问这个变量,这就很恐怖,代码会变的很混乱感。后来我学习了Stoyan Stefanovs Book JavaScript Patterns (http://astore.amazon.de/neoteccde-21/detail/0596806752),我的命名空间从此变的很干净。但是为什么这种基本的功能语言不能自带,而需要通过所谓的模式来解决这个问题呢? 前端框架分享 

Dart默认是“library”范围,只有声明为 public 的东西才能被外部访问。这样就很简单,不同的脚本不会相互影响。

7. Dart支持并行 
JS是没有真正的并行的。即使你通过jQuery发出一个异步请求,你也只有一个线程在工作。你可以通过HTML5,webworkers来解决这个问题。

Dart支持并行,支持Isolates,这有点像Erlang。当一个Isolate失败的时候,另外一个Isolate可以重启这个Isolate。这是不是很酷?这让Dart适合服务器端编程。是的,我知道Node.js,但是Dart天生支持这个功能。

8. JS 不支持 foreach 
在JS中,你这样遍历数组:

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

或者你可以这样来遍历对象:

1 for (key in elements) {
2   alert(elements[key]);
3 }

但这种方式是不推荐的。因为这种遍历方式得到的结果是不确定的,你也有可能拿到方法名字等你不想要的东西。当然,jQuery是你的救星!

使用Dart:

1 for (element in elements) {
2   // do something
3 }

没有比这更简单了吧。

9. 奇怪的数组初始化 
看看这段代码:

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

a1 是有五个元素的数组 [1,2,3,4,5]
a2 是有五个元素的数组 [undefined,undefined,undefined,undefined,undefined]

Dart就很清晰:

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

10. undefined 和 null 
在JS中,这两个值大多数情况可以互换,但有时候又不是,让人很头疼。Dart只有null。


总结 
JS有很多优点,有一些不错的模式。但是到目前为止,我还没有发现什么JS能做而Dart不能做的。Dart明显更优雅,更易于阅读(对我而言)。也许有一些JS狂人觉得JS好,可以理解。

Dart 比 JavaScript 更酷的10个理由

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
不妨先来打量一下JavaScript。JavaScript是唯一至今主流且基于原型的语言,虽然说支持面向对象,但
不妨先来打量一下JavaScript。JavaScript是唯一至今主流且基于原型的语言,虽然说支持面向对象,但
“ Google发布了 Dart——一个为简化Web应用开发而设计的新语言——的一个早期版本。不过,尽管它是
先说DART。在10月即将召开的GOTO开发者大会上,Google工程师说他们将宣布一个新的编程语言的细节,
四年前,曾经接触过dart. 第一印象是,很像java. 最近又拿出来学一学。 首先,得废点喉舌去说下dart的
import 'dart:html'; void main() { var dt1 = new DateTime.now(); querySelector('#datetext').te
此文运用的是优雅的Markdown而书 Dart官方建议使用的编译器是DartEditor,我下载下来看下,和Eclips
import 'dart:html'; import 'dart:core'; void main() { void myClick(Event e){ querySelector('#
import 'dart:html'; void main() { var data = { 'firstName' : 'John', 'lastName' : 'CarMark' }
一、什么是DOM DOM是文档对象模型(Document Object Model)的简称。 在这个模型中,用一个有若干结
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号