JavaScript:世界上誤解最深的語言

blogjava發表於2014-07-21

  JavaScript,或者叫 Mocha,或者叫 LiveScript,或者叫 JScript,又或者叫 ECMAScript,是世界上最流行的程式語言之一。事實上世界上的每一臺個人電腦都安裝並在頻繁使用至少一個JavaScript直譯器。JavaScript的流行完全是由於他在WWW指令碼語言領域中的地位決定的。

  儘管它很流行,但是很少有人知道JavaScript是一個非常棒的動態物件導向通用程式語言。這居然能成為一個祕密!這門語言為什麼被誤解如此之深?

  名字

  Java- 字首很容易使人聯想到Java,並認為它是Java的子集或簡化版的Java。看起來最初給它選這個名字是別有用心的,是故意混淆概念、故意製造"誤解"的。JavaScript不是解釋執行的Java。Java是解釋執行的Java。JavaScript是另外一種語言。

  JavaScript的語法和Java有相似之處,這就像Java的語法和C很相像一樣。但是它不是Java的子集,就像Java不是C的子集一樣。它在Java(Oak)最初打算進軍的領域中比Java更好。

  JavaScript不是Sun Microsystems的產品,Sun是Java的家。JavaScript是在Netscape被開發出來的。它最初叫LiveScript,嗯……還是這個名字好。

  -Script字尾讓人認為他不是一門真正的程式語言,和一門"程式語言"還有相當的差距。但是這只是應用領域的問題。和C相比,JavaScript是犧牲了效能但換來了豐富的表現力和靈活的形態。 

  披著C皮的Lisp

  JavaScript的類C語法,包括大括號和語句的形式,讓它看起來像普通的程式導向程式語言。這是一種誤解,因為JavaScript和函式式語言,比如 Lisp 或 Scheme,有更多的相似之處,而不是和C或Java。它使用陣列而不是列表,使用物件而不是屬性列表。函式是第一位的,它有閉包(closures 怎麼翻譯??),另外你還可以使用lambda表示式。

  型別轉換

  JavaScript最初被設計成在Netscape Navigator中執行,它在Navigator中的成功引領它成為事實上所有web瀏覽器的標準裝備。這就造就了"型別轉換"。JavaScript是程式語言中的 George Reeves(超人),是大量非web程式的稱職之選。

  移動靶

  JavaScript的最初幾版非常弱,沒有異常處理,沒有內部函式和繼承。現如今,它已經成為完全物件導向的程式語言。但是這門語言的許多思想是基於它不成熟的形式的。

  ECMA委員會,這門語言的管家,正在對它進行擴充套件,也在蓄意惡化它最大的問題:有太多的版本。這是混亂的根源。

  設計上的錯誤

  沒有什麼程式語言是完美的。JavaScript也有它設計上的錯誤,比如過載的+號隨著型別的不同既表示"相加"又表示"連線",和本該避免的有錯誤傾向的 with 語句。它的保留字策略過於嚴格。分號的插入是一個巨大的錯誤,比如作為字面正規表示式的符號時。這些失誤已直接導致程式設計中的錯誤,也使這門語言的整體設計遭人質疑。還好,這些問題中有許多都可以在良好的 lint 程式中得以緩解。

  這門語言的整體設計(上的問題)是相當明顯的。奇怪的是ECMAScript委員會並沒有對修正其中存在的問題表現出太大的興趣,也許他們更熱衷於製造新的問題。

  糟糕的實現

  JavaScript的一些早期實現有許多bug,這反過來對語言本身產生了很壞的影響。更糟糕的是這些滿是bug的實現是嵌入在滿是bug的web瀏覽器中的。

  糟糕的書

  幾乎所有的JavaScript書都是相當可怕的。它們包含錯誤,包含不好的例子,並鼓勵不好的做法。JavaScript語言的一些重要特性它們要麼沒有解釋清楚,要麼根本就沒有提及。我看過很多JavaScript的書,但我只能推薦一本:David Flanagan著的 JavaScript: The Definitive Guide (4th Edition) (《JavaScript權威指南 第四版》)。(作者們請注意:如果你們寫出了好書請發給我一份副本,我給你們校對。)

  “準標準”的標準

  ECMA公佈的官方語言規範的質量極其的差。不僅難讀而且極其難懂。它可為那些"糟糕的書"做出了不小的貢獻,因為那些作者無法通過這個標準文件來更深地理解這門語言。ECMA和TC39應該為此感到非常尷尬。

  業餘者

  使用JavaScript的人大多不是程式設計師,他們缺少寫良好程式的培訓和訓練。JavaScript有非常強大的表現力,不管怎樣他們也能使用它做有用的事情。這給了JavaScript一個”全然適合業餘愛好者而不適合專業程式設計師“的名聲。這很明顯是一個錯誤。

  物件導向

  JavaScript是物件導向的嗎?它有物件,它的物件可以包含資料以及對資料進行操作的方法,物件也可以包含其他的物件。它沒有類,但是它有建構函式來做類的事情,包括宣告類的變數和方法。它沒有面向類的繼承,但是他有面向原型的繼承。

  構建物件系統的兩大主要方法是繼承(is-a)和聚合(has-a)。這兩者JavaScript都有,但是它的動態天性允許有比聚合更好的實現方式。

  一些關於JavaScript不是真的物件導向的爭論其理由是它沒有提供資訊隱藏。也就是說JavaScript的物件沒有私有變數和私有方法:它的所有成員都是公開的。

  但是事實是JavaScript 的物件可以有私有變數和私有方法(點選這裡來看如何實現)。當然,之所以很少有人知道這個是因為JavaScript是世界上誤解最深的語言嘛。

  另一些關於JavaScript不是真的物件導向的爭論其理由是它沒有提供繼承。但是事實是JavaScript不但支援經典的繼承,而且支援其他一些程式碼重用的模式。

  翻譯:袁曉輝  原文連結: http://www.crockford.com/javascript/javascript.html 

相關文章