如何成為一個(gè)偉大的 JavaScript 程序員
遙想當(dāng)年還年少的時(shí)候,我的興趣愛(ài)好就跨越了各種不相關(guān)的領(lǐng)域。我喜歡數(shù)學(xué),如同我深?lèi)?ài)歷史那樣。我的目標(biāo)是成為像文藝復(fù)興時(shí)期多才多藝的偉人那樣——在多個(gè)領(lǐng)域都有出色表現(xiàn)。這是一個(gè)艱巨的任務(wù)——突然之間我發(fā)現(xiàn)自己正面臨著“樣樣皆通,樣樣稀松”的危險(xiǎn)。
我開(kāi)始考慮鉆研某些領(lǐng)域,這樣至少我還可以成為一個(gè)“精通某些領(lǐng)域”的人。那么我該怎么做,才能既專(zhuān)注于某個(gè)領(lǐng)域,同時(shí)又能學(xué)到軟件開(kāi)發(fā)所需的大量知識(shí)?
這篇文章主要概述在我5年工作經(jīng)驗(yàn)的基礎(chǔ)上,我成為優(yōu)秀JavaScript開(kāi)發(fā)人員所使用的技術(shù)和資源。
當(dāng)前大多數(shù)Web開(kāi)發(fā)人員面臨著這樣一個(gè)共同的問(wèn)題:他們必須在多個(gè)不同的領(lǐng)域領(lǐng)先于他人——從數(shù)據(jù)庫(kù)到后端架構(gòu),到前端用戶界面,再到使用良好的CSS知識(shí)修正用戶界面。
閱讀書(shū)籍首先,也是最重要的一點(diǎn)是,你必須付出努力才能脫穎而出。雖然你也可以在無(wú)心中獲得點(diǎn)點(diǎn)滴滴的積累,例如,不時(shí)地閱讀一些博客文章,而且老實(shí)說(shuō),因?yàn)檫@種方法最初的時(shí)間和精力的投入要求低得多,所以更簡(jiǎn)單。這樣的學(xué)習(xí)模式顯然比你專(zhuān)門(mén)和刻意的學(xué)習(xí)過(guò)程要花費(fèi)更多的時(shí)間。關(guān)于這種窘境的解決方式也很簡(jiǎn)單:閱讀書(shū)籍。
書(shū)籍是人類(lèi)進(jìn)步的階梯。文字是我們讓知識(shí)以濃縮的形式代代相傳的工具。成為Web技術(shù)專(zhuān)家有一個(gè)要解決的問(wèn)題是,你必須學(xué)會(huì)何時(shí)遠(yuǎn)離網(wǎng)絡(luò)本身。網(wǎng)絡(luò)本身就存在著讓人混亂和分心的內(nèi)容,所以我要給出的第一個(gè)建議是,要閱讀相關(guān)主題的書(shū)籍。
對(duì)于JavaScript中,可以先從以下書(shū)籍開(kāi)始:《JavaScript the Good Parts》就像是JavaScript中的《圣經(jīng)》。雖然這本書(shū)已經(jīng)有點(diǎn)古老了,但依然是最好的起始點(diǎn)。《JavaScript: the Definitive Guide》也是我們必需的,雖然你可能會(huì)將它當(dāng)作是參考書(shū)。 jQuery創(chuàng)始人John Resig的《Secrets of the JavaScript Ninja》也值得關(guān)注。此外,你還可以閱讀電子書(shū),非常方便,很多在線電子書(shū)還是免費(fèi)的。另外,JavaScript Guide雖然不是書(shū),但深受Mozilla開(kāi)發(fā)人員的信賴(lài)和青睞。
腳本庫(kù)的學(xué)習(xí),使用和閱讀接下來(lái)最重要的一個(gè)步驟是去了解腳本庫(kù)。書(shū)籍教你如何讀懂語(yǔ)言,庫(kù)教你如何應(yīng)用它。關(guān)于腳本庫(kù)你需要做這兩件重要的事情:使用它們,閱讀它們的源代碼。
對(duì)于庫(kù)的使用,需要了解以下幾個(gè)重點(diǎn)的庫(kù):jQuery,Backbone,underscore以及React、 Angular和Ember之一。這并不是說(shuō)你必須要使用這些庫(kù),但任何像樣的JavaScript開(kāi)發(fā)人員至少應(yīng)該有一定的使用這些庫(kù)的經(jīng)驗(yàn)(無(wú)論好壞)。
提升JavaScript技能的第二件重要的事情是閱讀這些庫(kù)的源代碼。我強(qiáng)烈建議閱讀Backbone和underscore的源代碼,因?yàn)樗鼈儗?xiě)得非常優(yōu)美。閱讀和理解underscore可以提高函數(shù)式編程的技巧。另一個(gè)值得閱讀源代碼,也是其他開(kāi)發(fā)人員推薦給我的庫(kù)是mootols(我個(gè)人并不使用mootools,也沒(méi)有閱讀過(guò)它的源代碼。)
剩下的庫(kù),如React和Ember等,理解起來(lái)可能很難,但非常值得。此外還應(yīng)該瀏覽一下其他庫(kù)的源代碼,看看它們是如何構(gòu)建代碼庫(kù)的,并嘗試探索一些新的模式。其他著名的可使用和閱讀其源代碼的庫(kù)包括D3、highcharts和moment.js。
練習(xí)與自問(wèn)問(wèn)題要成為一個(gè)好的JavaScript開(kāi)發(fā)人員的關(guān)鍵步驟是練習(xí),許許多多的練習(xí)。理想的情況是,練習(xí)的重點(diǎn)不在于DOM,而在于語(yǔ)言,所以一定要確保有一個(gè)可以運(yùn)行node.js的測(cè)試工具。做各種瑣碎又大量的node.js練習(xí)。研究編碼招式,經(jīng)歷使用JavaScript的不同方式:閉包,原型,擴(kuò)展數(shù)組(map、filter)等。在做練習(xí)的同時(shí),要開(kāi)始在腦中形成JavaScript的基本思想。
我的一個(gè)朋友,Armagan,一位優(yōu)秀的JavaScript程序員,也是一個(gè)使用《Pro JavaScript Design Patterns》用于講座的老師,所以這本書(shū)值得一閱。
在學(xué)習(xí)的同時(shí),要試著回答一些問(wèn)題,例如:原型如何繼承工作?閉包的定義?關(guān)鍵字含義如何改變?如何使用apply/bind/map/filter/call?收集一系列JavaScript開(kāi)發(fā)人員需要面臨的共同源要點(diǎn),并試著用自己的話來(lái)解釋。用書(shū)面或口頭的形式向另一個(gè)人解釋這些概念,有利于極大地提高你的技能。在練習(xí)的同時(shí),盡量去思考“如果是那種情況,又該如何?”的情景。例如,“如果我使用兩次bind,那個(gè)這個(gè)”this“會(huì)是什么意思?jQuery如何確保this關(guān)鍵字指向jQuery對(duì)象,而不是全局對(duì)象?這個(gè)庫(kù)如何完成一定的功能?”等等,這些都是你應(yīng)該時(shí)常問(wèn)問(wèn)自己的常見(jiàn)問(wèn)題。
學(xué)習(xí)標(biāo)準(zhǔn)接下來(lái)需要了解的是EcmaScript標(biāo)準(zhǔn)。研讀最新的EcmaScript標(biāo)準(zhǔn)副本。同時(shí),還可以試著了解JavaScript中即將推出的功能,如ES6和ES7。近期已經(jīng)出現(xiàn)了例如promises、modules、generators、comprehensions等新功能,好好閱讀標(biāo)準(zhǔn),也可以閱讀專(zhuān)業(yè)書(shū)籍,如Nicholas Zakas的《Understanding EcmaScript 6》或Axel Rauschmayer博士的《Exploring JS》,或許會(huì)有所幫助。從主要源學(xué)習(xí)標(biāo)準(zhǔn)以及探索新增的語(yǔ)言才是通往專(zhuān)業(yè)化道路的途徑和方法。
利用網(wǎng)絡(luò)資源我前面提到過(guò)利用網(wǎng)絡(luò)來(lái)了解網(wǎng)絡(luò)是危險(xiǎn)的,但是現(xiàn)在我要提議的是我們還可以利用網(wǎng)絡(luò)來(lái)獲取最好的資源。《Hacker News》就是一個(gè)很好的來(lái)源,但是持續(xù)的跟蹤通常會(huì)耗費(fèi)更多的時(shí)間,因?yàn)檎嬲杏玫男畔⒈壤呛艿偷摹O喾矗€不如直接瞄準(zhǔn)每周摘要如《JavaScript weekly》呢。隨著時(shí)間的推移,你自然會(huì)領(lǐng)悟到哪些庫(kù)或技術(shù)越來(lái)越有吸引力。可以在Twitter上找找有影響力的JavaScript開(kāi)發(fā)人員。 其他的網(wǎng)絡(luò)資源包括博客如Toptal Blogs、Rebecca Murphey’s blog和Nicholas Zakas’ blog等。
另一個(gè)非常重要的網(wǎng)絡(luò)資源是視頻會(huì)議和教育視頻。說(shuō)到會(huì)議,JSConf系列的品質(zhì)就很高。至于教育視頻,我強(qiáng)烈建議Pluralsight,因?yàn)樗麄冇兄帉?xiě)高質(zhì)量課程經(jīng)驗(yàn)的開(kāi)發(fā)軍團(tuán)。
簡(jiǎn)而言之讀書(shū),書(shū)中自有信息之精華。了解基本的庫(kù),如jQuery、underscore和Backbone,閱讀源代碼。練習(xí),試著用自己的話去解釋常見(jiàn)的JavaScript概念,例如繼承。就上述主題做演講和講座。通讀新版本的標(biāo)準(zhǔn),使用最新增加的語(yǔ)言。利用網(wǎng)絡(luò)資源,查看摘要和博客,以及視頻會(huì)議和教育視頻。 結(jié)論不斷重復(fù)上述步驟,并參與到大量的項(xiàng)目中去有助于你快速提高你的JavaScript技能。但始終要牢記,只有付出才會(huì)有回報(bào),才會(huì)有望成為專(zhuān)業(yè)人士。我自認(rèn)為自己是一個(gè)很好的JavaScript程序員,但是要想成為專(zhuān)業(yè)人士我依然還有很長(zhǎng)的路要走,還需要不斷地學(xué)習(xí)和掌握知識(shí)和技術(shù)。
最后祝學(xué)習(xí)快樂(lè),愿與君共勉!
英文原文:How to Become a Great JavaScript Developer 翻譯:codeceo
相關(guān)文章:
1. ASP.NET MVC實(shí)現(xiàn)城市或車(chē)型三級(jí)聯(lián)動(dòng)2. IntelliJ IDEA設(shè)置條件斷點(diǎn)的方法步驟3. SSM框架JSP使用Layui實(shí)現(xiàn)layer彈出層效果4. IntelliJ IDEA導(dǎo)入jar包的方法5. Python利用百度地圖獲取兩地距離(附demo)6. 一篇文章弄清楚Ajax請(qǐng)求的五個(gè)步驟7. java基于spring boot本地上傳圖片示例解析8. ASP基礎(chǔ)入門(mén)第八篇(ASP內(nèi)建對(duì)象Application和Session)9. UTF8轉(zhuǎn)成GB2312亂碼問(wèn)題解決方案10. 刪除docker里建立容器的操作方法
