|
作者: 阮一峰
日期: 2011年6月24日
1.
今天把這部分補全,從歷史的角度,說明Javascript到底是如何設(shè)計出來的。
只有了解這段歷史,才能明白Javascript為什么是現(xiàn)在的樣子。我依據(jù)的資料,主要是Brendan Eich的自述。
2.
上一篇文章寫道:
"1994年,網(wǎng)景公司(NETscape)發(fā)布了Navigator瀏覽器0.9版。這是歷史上第一個比較成熟的網(wǎng)絡(luò)瀏覽器,轟動一時。但是,這個版本的瀏覽器只能用來瀏覽,不具備與訪問者互動的能力。......網(wǎng)景公司急需一種網(wǎng)頁腳本語言,使得瀏覽器可以與網(wǎng)頁互動。"
網(wǎng)頁腳本語言到底是什么語言?網(wǎng)景公司當(dāng)時有兩個選擇:一個是采用現(xiàn)有的語言,比如Perl、Python、Tcl、Scheme等等,允許它們直接嵌入網(wǎng)頁;另一個是發(fā)明一種全新的語言。
這兩個選擇各有利弊。第一個選擇,有利于充分利用現(xiàn)有代碼和程序員資源,推廣起來比較容易;第二個選擇,有利于開發(fā)出完全適用的語言,實現(xiàn)起來比較容易。
到底采用哪一個選擇,網(wǎng)景公司內(nèi)部爭執(zhí)不下,管理層一時難以下定決心。
3.
就在這時,發(fā)生了另外一件大事:1995年Sun公司將Oak語言改名為Java,正式向市場推出。
Sun公司大肆宣傳,許諾這種語言可以"一次編寫,到處運行"(Write Once, Run Anywhere),它看上去很可能成為未來的主宰。
網(wǎng)景公司動了心,決定與Sun公司結(jié)成聯(lián)盟。它不僅允許Java程序以applet(小程序)的形式,直接在瀏覽器中運行;甚至還考慮直接將Java作為腳本語言嵌入網(wǎng)頁,只是因為這樣會使HTML網(wǎng)頁過于復(fù)雜,后來才不得不放棄。
總之,當(dāng)時的形勢就是,網(wǎng)景公司的整個管理層,都是Java語言的信徒,Sun公司完全介入網(wǎng)頁腳本語言的決策。因此,Javascript后來就是網(wǎng)景和Sun兩家公司一起攜手推向市場的,這種語言被命名為"Java+script"并不是偶然的。
4.
此時,34歲的系統(tǒng)程序員Brendan Eich登場了。1995年4月,網(wǎng)景公司錄用了他。
Brendan Eich的主要方向和興趣是函數(shù)式編程,網(wǎng)景公司招聘他的目的,是研究將Scheme語言作為網(wǎng)頁腳本語言的可能性。Brendan Eich本人也是這樣想的,以為進入新公司后,會主要與Scheme語言打交道。
僅僅一個月之后,1995年5月,網(wǎng)景公司做出決策,未來的網(wǎng)頁腳本語言必須"看上去與Java足夠相似",但是比Java簡單,使得非專業(yè)的網(wǎng)頁作者也能很快上手。這個決策實際上將Perl、Python、Tcl、Scheme等非面向?qū)ο缶幊痰恼Z言都排除在外了。
Brendan Eich被指定為這種"簡化版Java語言"的設(shè)計師。
5.
但是,他對Java一點興趣也沒有。為了應(yīng)付公司安排的任務(wù),他只用10天時間就把Javascript設(shè)計出來了。
由于設(shè)計時間太短,語言的一些細(xì)節(jié)考慮得不夠嚴(yán)謹(jǐn),導(dǎo)致后來很長一段時間,Javascript寫出來的程序混亂不堪。如果Brendan Eich預(yù)見到,未來這種語言會成為互聯(lián)網(wǎng)第一大語言,全世界有幾百萬學(xué)習(xí)者,他會不會多花一點時間呢?
總的來說,他的設(shè)計思路是這樣的:
(1)借鑒C語言的基本語法;
(2)借鑒Java語言的數(shù)據(jù)類型和內(nèi)存管理;
(3)借鑒Scheme語言,將函數(shù)提升到"第一等公民"(first class)的地位;
(4)借鑒Self語言,使用基于原型(prototype)的繼承機制。
所以,Javascript語言實際上是兩種語言風(fēng)格的混合產(chǎn)物 ----(簡化的)函數(shù)式編程+(簡化的)面向?qū)ο缶幊獭?/strong>這是由Brendan Eich(函數(shù)式編程)與網(wǎng)景公司(面向?qū)ο缶幊蹋┕餐瑳Q定的。
6.
多年以后,Brendan Eich還是看不起Java。
他說:
"Java(對Javascript)的影響,主要是把數(shù)據(jù)分成基本類型(primitive)和對象類型(object)兩種,比如字符串和字符串對象,以及引入了Y2K問題。這真是不幸啊。"
把基本數(shù)據(jù)類型包裝成對象,這樣做是否可取,這里暫且不論。Y2K問題則是直接與Java有關(guān)。根據(jù)設(shè)想,Date.getYear()返回的應(yīng)該是年份的最后兩位:
var date1 = new Date(1999,0,1);
var year1 = date1.getYear();
alert(year1); // 99
但是實際上,對于2000年,它返回的是100!
var date2 = new Date(2000,0,1);
var year2 = date2.getYear();
alert(year2); // 100
如果用這個函數(shù)生成年份,某些網(wǎng)頁可能出現(xiàn)"19100"這樣的結(jié)果。這個問題完全來源于Java,因為Javascript的日期類直接采用了Java.util.Date函數(shù)庫。Brendan Eich顯然很不滿意這個結(jié)果,這導(dǎo)致后來不得不添加了一個返回四位數(shù)年份的Date.getFullYear()函數(shù)。
如果不是公司的決策,Brendan Eich絕不可能把Java作為Javascript設(shè)計的原型。作為設(shè)計者,他一點也不喜歡自己的這個作品:
"與其說我愛Javascript,不如說我恨它。它是C語言和Self語言一夜情的產(chǎn)物。十八世紀(jì)英國文學(xué)家約翰遜博士說得好:'它的優(yōu)秀之處并非原創(chuàng),它的原創(chuàng)之處并不優(yōu)秀。'(the part that is good is not original, and the part that is original is not good.)"
it知識庫:Javascript誕生記,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。