jQuery之父訪談錄:JavaScript和HTML一樣長壽
編程初體驗(yàn)
記者:你是如何開始編程的?
John Resig:第一次編程大概是在初中,14、15歲,當(dāng)時有個朋友帶來張軟盤,里面有QBASIC。在DOS系統(tǒng)下他向我展示了他自己的程序,我覺得非常有意思。從那時起我就開始想編程了,先后借了很多相關(guān)的書。最初是學(xué)習(xí)編寫HTML,之后又轉(zhuǎn)向CGI。
記者:你編寫的第一個有意思的程序是什么,還有印象嗎?
John Resig認(rèn)為,JavaScript和HTML一樣會長久存在,20年內(nèi)開發(fā)者肯定會一直用JavaScript寫網(wǎng)頁應(yīng)用程序John Resig:高中時,有一陣我通過編寫網(wǎng)站應(yīng)用來掙錢。我還會做一些諸如網(wǎng)站設(shè)計的工作,當(dāng)然沒有專業(yè)人員做得那么好。記得曾編寫了一個訂早餐的網(wǎng)頁應(yīng)用,讓那些熬夜無暇早起買早餐的人通過這個網(wǎng)頁應(yīng)用訂餐。不過,這還算不上最有意思的程序。我的第一個最有趣的程序是在大學(xué)時編寫的。那時我們要建立自己的時間表,以分配好上課時間,所以我編了一個選課的程序,它可以推薦出最優(yōu)的選課結(jié)果,例如:如果你要選數(shù)學(xué)、計算機(jī)和除此之外的一門科學(xué)課程,程序可以推薦出可在一天內(nèi)完成三門課程的時間表,這樣你就有六天的空閑時間去做自己想做的事情。
記者:學(xué)生時代的生活和以后的編程生涯,兩者之間有沒有內(nèi)在的聯(lián)系?
John Resig:這說不太清楚,我喜歡編程,它可以讓我完全理解一個東西。選擇Web編程是因?yàn)樽约涸敢庾鰟e人不樂意做的事情。比如很多人不愿意處理同樣的網(wǎng)頁在不同瀏覽器下表現(xiàn)各異的問題。但這很有挑戰(zhàn),也很有樂趣。
記者:能不能談?wù)勀阍诖髮W(xué)生活中印象最深的事情?
John Resig:對我來說最重要的事情,是那些計算機(jī)科學(xué)課程。大學(xué)期間我并沒做很多Web編程,而是做了很多和數(shù)據(jù)庫相關(guān)的工作。這是我感興趣的方面。我還喜歡研究社區(qū),做數(shù)據(jù)挖掘研究,其中就包括判斷社交網(wǎng)站怎樣增長之類,那時我還發(fā)表了兩篇關(guān)于數(shù)據(jù)挖掘的論文。離開大學(xué)后,我又回到Web編程,盡管數(shù)據(jù)挖掘很有意思,但我還是覺得Web編程的吸引力更大。
記者:大學(xué)最喜歡的計算機(jī)課程有哪些?
John Resig:我喜歡有挑戰(zhàn)性的課。例如XML,我本來以為課程很簡單,可以輕松得個A。結(jié)果老師第一堂課就把我知道的東西都講完了,從第二節(jié)課開始所講內(nèi)容我完全聽不懂,很難學(xué),結(jié)果我得了B。但我還是很自豪,因?yàn)閷W(xué)了很多東西。
jQurey 背后的故事
記者:向我們透露一些jQuery背后的故事吧。最開始您是怎樣做的?
John Resig:做Web編程時,我非常討厭瀏覽器的Bug,不同的瀏覽器有不同的Bug,而且數(shù)量非常多。于是我用JavaScript做了CSS選擇引擎,之后還做了個動畫引擎,都是自娛自樂。但與此同時我發(fā)現(xiàn)自己不能將制作的一些應(yīng)用放到瀏覽器里。為了將應(yīng)用放到Firefox瀏覽器中,我開始制作相關(guān)的API,以應(yīng)用那個CSS選擇引擎和動畫引擎,這些最終成為了jQuery。幾個月后,我將那些應(yīng)用做進(jìn)Firefox里,之后在IE里也可以運(yùn)行。如今這仍是我的目標(biāo)——讓每個人都可以在網(wǎng)頁里寫點(diǎn)什么,并且寫的東西能夠在瀏覽器中順利運(yùn)行出來。
記者:支撐jQuery的基本原理有哪些?
John Resig:原則很簡單。作為一名程序員,我希望代碼簡潔,不希望在編程的時候不停地重復(fù)某些內(nèi)容,設(shè)計jQuery的目標(biāo)就是為了簡化代碼,使程序更高效。
記者:jQuery是如何把簡單和高效結(jié)合在一起的?
John Resig:很多人想直接做大項(xiàng)目,例如像Gmail、Yahoo!Mail之類。但實(shí)際上通過很簡單的過程也可以解決大項(xiàng)目中一些很困難的關(guān)鍵點(diǎn),化大為小,化繁為簡,jQuery就是這樣做的。
記者:如果能重新再來一次,你會在哪些方面做出設(shè)計改變?
John Resig:我要改一些方法的名稱。初期在命名上出現(xiàn)了一些失誤,后來我花了很多時間才理解到j(luò)Query應(yīng)該是現(xiàn)在這樣。有些事情如果一開始就做好,可能會少走很多彎路。
記者:談?wù)刯Query的研發(fā)過程吧。
John Resig:我們主要的資源是jQuery的Bug Tracker,有一個Team專門經(jīng)營Bug Tracker。我負(fù)責(zé)修改這些Bug。最終我們有一個需要修改的Bug列表。然后有人改程序,提交給別人通過,并處理這些Bug。大多數(shù)時候都是我來改Bug,發(fā)布新版本。
記者:中國的程序員該如何做才能參加到這個項(xiàng)目?
John Resig:直接加入就可以。所有人都可以看到內(nèi)部的每次代碼提交,然后更優(yōu)秀的程序員會加入Bug Tracker。他們能看到我們發(fā)現(xiàn)問題和處理問題的整個過程,從而學(xué)會怎樣發(fā)布補(bǔ)丁。我們的小組一共20個人,只有3個代碼的貢獻(xiàn)者,其余17人都在做各種各樣其他事情。jQuery網(wǎng)站是世界排名前700位的網(wǎng)站,所以有很多工作需要處理。
記者:在中國有沒有正式的文檔網(wǎng)站?
John Resig:有jQuery.org.cn,但這不是正式的,不過里面有jQuery文檔的翻譯資料。我們急需有人幫助翻譯這些文檔。
記者:jQuery的未來怎樣?
John Resig:我們基本不加入新功能,目前大多數(shù)工作都是優(yōu)化,讓jQuery變得更快、更強(qiáng)、更容易理解。未來的工作也是優(yōu)化,使jQuery功能更清晰化。
開源是JavaScript 的出路
記者:說說你學(xué)習(xí)JavaScript的過程?
John Resig:從高中時我就開始使用Java-Script,具體做什么記不大清了。大學(xué)時我加入一個研究工作組做一些商業(yè)項(xiàng)目,例如為一些地方公司設(shè)計網(wǎng)頁。設(shè)計師的工作是用Photoshop處理網(wǎng)頁圖片,而我的工作是將這些圖片用CSS展現(xiàn)在網(wǎng)站上,這需要在Firefox瀏覽器下呈現(xiàn)出相應(yīng)的效果。這期間公司還讓我做的事情是在網(wǎng)頁上顯示一個特殊的卷軸效果,所以必須用JavaScript編寫。我一直在琢磨如何寫這個腳本,直到有一天我改了腳本中某個元素屬性,這個功能就實(shí)現(xiàn)了。我很高興,開始系統(tǒng)學(xué)習(xí)JavaScript,之后就用它編程。
記者:最開始你用的是什么庫?
John Resig:用Prototype,這是2005年出現(xiàn)的一款非常棒的JavaScript基礎(chǔ)類庫,對JavaScript做了大量的擴(kuò)展,而且很好地支持了Ruby on Rails。Prototype吸引我的一點(diǎn)是代碼干凈整潔。當(dāng)我第一次看到Prototype的時候,很難想象JavaScript類庫代碼可以做到如此簡潔。Prototype非常漂亮,讓人產(chǎn)生用它寫代碼的欲望。
記者:你認(rèn)為什么時候是JavaScript庫開源的最佳時機(jī)?
John Resig:JavaScript與其他瀏覽器語言有很多不同,它的特點(diǎn)是大家都可以看到源代碼,所以我認(rèn)為從一開始就要開源。如果你注意觀察JavaScript的庫,就會發(fā)現(xiàn)所有開源的庫都挺好,而所有閉源的庫都不行。其實(shí)現(xiàn)在基本已經(jīng)沒有人再用閉源的JavaScript庫了。
記者:我知道有些中國的公司開始設(shè)計新的框架和JavaScript庫,并打算開源,你對他們有什么建議嗎?
John Resig:開源是需要的,但最重要的是知道你的用戶是誰,否則就會跟他們有距離。我設(shè)計jQuery時就遇到了類似的問題,要考慮究竟哪些人需要用我設(shè)計的類庫。目前JavaScript還是有發(fā)展的空間,但是如果創(chuàng)造全新的東西就可能沒太大必要。我對開源公司的建議是必須放棄自己的公司立場,把這個當(dāng)成一個獨(dú)立的項(xiàng)目,公司只是這個項(xiàng)目的一個用戶。比如公司有一個需求,也要走正式的申請、Debug之類的流程。也許有些人會覺得這是公司的資源,但如果你要開源,就必須放棄控制。
記者:對剛開始使用JavaScript的開發(fā)者有什么建議?
John Resig:剛開始使用JavaScript的開發(fā)者估計對瀏覽器方面的了解也很少。我的建議是用庫。不要把時間花在那些瀏覽器的Bug上,一開始就直接用各種庫。
記者:你怎樣看JavaScript的未來?談一下服務(wù)器端的node.js?
John Resig:我對JavaScript的未來很樂觀。因?yàn)榫W(wǎng)絡(luò)和瀏覽器會存在很長時間,所以JavaScript和HTML一樣會長久存在。20年內(nèi)大家肯定會一直用JavaScript寫Web應(yīng)用。它是一種很特別的語言,在服務(wù)器端也可以用JavaScript。我喜歡JavaScript的原因是它可直接用在瀏覽器上,它跟Python不一樣,很少有語言可以直接用在瀏覽器上。在服務(wù)器端的node.js是很酷的東西,它讓JavaScript脫離瀏覽器而存在。
優(yōu)秀程序員的標(biāo)準(zhǔn)
記者:談?wù)勀阍贛ozilla的工作?
John Resig:我以前是JavaScript程序員,2007年2月加入Mozilla,工作了幾年。后來jQuery變得很大,我必須全力來做。所以向Mozilla的主管說我要做jQuery,他非常支持,認(rèn)為這是很棒的事情。所以后來,我就可以將全部精力放在jQuery上。
記者:你最常用的工具是什么?
John Resig:用瀏覽器,12~20種,不同的版本,不同的類型。我還要使用各類系統(tǒng)如Windows、Mac等。
此外Firebug是一款很棒的工具。
記者:你現(xiàn)在是在本地還是在云端工作?
John Resig:我基本還是在本地,在云端工作的確很好,因?yàn)樵O(shè)定所有的模擬器是很困難的,所以我們都是設(shè)定一次,然后放到云端,這樣能避免一些測試的問題。
記者:你覺得好的程序員應(yīng)該是怎樣的?
John Resig:面試JavaScript程序員時,我一般問兩類問題,一類是JavaScript的技術(shù)問題,另一類是瀏覽器Bug方面的。比如你最喜歡的瀏覽器Bug,要是他不能回答,就說明他做的工作不夠。喜歡這個工作的人,都會有花兩三天修復(fù)一個瀏覽器Bug的經(jīng)歷。
記者:你覺得學(xué)習(xí)數(shù)學(xué)或者理論、算法是不是對程序員很重要?
John Resig:對有些程序員是,但對JavaScript程序員則不一定,這取決于你要做什么工作。在大學(xué)時我做數(shù)據(jù)挖掘方面的工作,需要很強(qiáng)的理論背景。在用JavaScript時,我學(xué)了一些語言基礎(chǔ)方面的東西。當(dāng)然多學(xué)知識肯定會讓你有更好的理解。算法有時不一定都能用上,但熟悉語言的基礎(chǔ)理論會對自己有很大幫助。
HTML 的未來
記者:HTML、JavaScript在將來是不是會占統(tǒng)治地位?
John Resig:現(xiàn)在已經(jīng)處于統(tǒng)治地位了,以后瀏覽器和web只會更流行。它是網(wǎng)絡(luò)的核心,不像Flash不能運(yùn)行在iPhone上。
記者:HTML5會成功替代Flash嗎?
John Resig:大家要用Flash主要是為了視頻、游戲。但現(xiàn)在主要的視頻網(wǎng)站都已經(jīng)轉(zhuǎn)入HTML5,我認(rèn)為隨著更多的瀏覽器支持HTML5功能,F(xiàn)lash就會更加無關(guān)緊要。
記者:越來越多人在用HTML和JavaScript,會不會取代所有的本地應(yīng)用?
John Resig:是的,因?yàn)橛盟鼈兛梢蚤_發(fā)很多功能。HTML會不會取代所有的本地應(yīng)用,關(guān)鍵還是看要用什么功能,比如你不能用HTML編寫瀏覽器,還是要使用底層的語言。當(dāng)然不排除但首先Web技術(shù)可能變得更厲害,厲害到能開發(fā)瀏覽器的程度,就可以編瀏覽器。要讓所有瀏覽器都能支持,這是未來的關(guān)鍵。
編者按:2011年5月,John Resig離職Mozilla,加入在線教育集團(tuán)Khan Academy。在那里,他仍繼續(xù)從事jQuery相關(guān)工作,同時負(fù)責(zé)該組織的開源項(xiàng)目及未來的iPad應(yīng)用的開發(fā)。Khan Academy是一個非盈利組織,正在嘗試對“學(xué)生的學(xué)習(xí)方法及老師的教育方法”進(jìn)行一次徹底變革。John Resig的加入,意在為教育提供更好的工具,讓更多的人參與到開源中來,為提升教育質(zhì)量貢獻(xiàn)一份力。
原文:http://www.programmer.com.cn/7787/
【編輯推薦】