最近,我一直在拿這個問題問自己。之所以會有這個問題,我基于兩個前提:第一、我自認為自己不笨;第二、我學習和使用javascript也有一段時間了,并且自己學習還算努力。 排除第一個答案不討論。我們來討論下第二個和第三個答案。 答案二:他之前學過的、接觸過的東西使他對這個知識有啟發(fā),我這里簡單的歸結為積累,關于積累問題,我上一篇博客程序員的學習和積累有談到。 說到這,我又想起了我深受毒害的應試教育。應試教育缺乏的正是動手和實踐知識的場所或曰方式。很多時候我總是懶于動手,為什么懶于動手?難道是我真的懶嗎?我不承認,我不動手是因為我找不到動手的理由,或是不知道如何動手。拿寫一個javascript庫或框架為例,為什么我到現(xiàn)在還沒有寫一個javascript庫?首先我找不到寫它的理由,現(xiàn)在這么多流行、易用且被廣泛使用的javascript庫或框架了,有必要再寫一個嗎?就算我寫了,公司會使用它嗎?如果沒有對其他庫或框架的深刻理解和認識,只是把各個庫或框架中的一些東西拼湊在一起,甚至不知道其中一個函數(shù)實現(xiàn)的內(nèi)部原理,那能叫我寫的嗎?其次,我找不到入手的地方。在沒有對其他框架有深刻認識,自己能找到其中的缺陷、不足而加以修正和實現(xiàn)之前,我找不到入手的地方。 解釋下答案: 功夫下在和工作有關的地方,這需要有強烈的責任心和主人翁意識。我們需要深刻理解這句話,功夫下在和工作有關的地方不是說,每天把上司交給自己事情做完、沒有bug、達到需求就可以了。而是要做得更好,我想提出3點,也給自己樹立目標: 1、用最優(yōu)的方案實現(xiàn)需求。在自己的已有知識結構、能力、經(jīng)驗上用最好的方式實現(xiàn)需求,在此基礎上努力搜尋業(yè)界相關的解決方案比較優(yōu)劣,選出最佳的方案,最終實現(xiàn)需求。 2、關心自己已做完工作,關注業(yè)界的相關新思想、新技術、新理念,把已完成的工作,用最新最優(yōu)的方案予以重構,并在適當?shù)臅r機在產(chǎn)品上得以實現(xiàn)。 3、關注自己所負責工作的未來,把產(chǎn)品當做自己的孩子,努力將他引向最美好的未來。努力將自己所負責的產(chǎn)品打造成為業(yè)界的標桿(特別是自己所負責的部分,那是自己影響圈內(nèi)的事情)。 語言層面:編程語言之間是想通的,至少高級語言是想通的(相對于機器語言和匯編語言),javascript是一門特殊的語言,既可面向過程、又可面向?qū)ο蟆S腥讼矚g它弱類型語言的特性,而將其語言本身的特性發(fā)揮得淋漓盡致。有人喜歡java這類純面向?qū)ο笳Z言的嚴謹,而使用一些功能函數(shù)將其包裝成完全的面向?qū)ο?,并采用它實現(xiàn)了一些常見設計模式。所以說,真正要精通javascript這門語言本身,需要對其他語言的一些理解(至少是了解)。鑒于目前javascript從業(yè)人員的構成,非計算機專業(yè)科班出身的同學可能需要努力補補課。 環(huán)境層面:javascript運行的環(huán)境目前有瀏覽器端和服務器端,將來可能有機會到嵌入式設備中。目前大部分應用主要集中在瀏覽器端,而瀏覽器廠商為了各自利益等各種歷史原因造成的javascript運行環(huán)境兼容性問題,也是javascript從業(yè)人員較為頭疼的問題。 業(yè)務層面:很多其他語言有功能完善的底層API、工具包,抱歉,javascript暫時沒有(瀏覽器端、nodejs開始有雛形,希望commonJS規(guī)范能夠一路走好)。所以各種庫、框架對于一些基本業(yè)務需求都提供了類似但非相同的實現(xiàn)。一個優(yōu)秀javascript程序員需要辨別各種框架或庫中的業(yè)務實現(xiàn),或編寫出自己的業(yè)務實現(xiàn)。 綜上,要在語言、環(huán)境、業(yè)務三個方面都精通,確實是需要花費很大的功夫。一個人的精力是有限的,其他語言積累幾十年的東西,你想一個人在javascript得到實現(xiàn)是不太可能的。術業(yè)有專攻,不是說你是javascript高手,javascript的方方面面你都能做到最好。 運用javascript把工作做得最好,才是javascript高手! PS:這是本人對自身問題的思考和分析,之所以發(fā)到首頁來,是希望能給有同樣疑惑、同樣迷茫的同學帶來些思考。分享這篇博文花了4小時的寫作時間,如果你有同感,如果你覺得我還算用心,請幫忙右下角推薦一下,這樣能給更多的同學帶來一點思考和幫助。如果你以為我是javascript高手,只是來學習經(jīng)驗的,卻沒有半點收獲,失望而歸,請拍磚 作者 慢熱君
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:空間域名、網(wǎng)站空間、營銷軟件、網(wǎng)站建設、利通網(wǎng)站維護、網(wǎng)站推廣。
JS高手……這個范圍太廣了,能在幾個領域把JS用到極致就是專家了:
Node.js 可以開發(fā)服務器、API,當后端工程師
Hybrid、React Native 可以開發(fā)移動應用,當移動端工程師
nw.js、electron、React Desktop 可以開發(fā)桌面應用,當桌面應用工程師
Canvas、OpenGL Unity 可以開發(fā)游戲,當游戲開發(fā)工程師
Sketch、FramerJS 可以搞設計、搞原型,當交互設計師
Ruff 可以搞嵌入式開發(fā),做嵌入式開發(fā)工程師
Cylon、Nodebots、Robotjs 可以做硬件開發(fā),做硬件工程師
…………
只有你想不到,沒有做不到,JS的生態(tài)是它最大的優(yōu)勢,要說自己是JS高手,那還遠得很呢。
學習JavaScript的最佳方法分享
學習新的東西是件可怕的事。對我來說,掌握一項新技能最大的問題是,我不知道自己懂什么。鑒于此,定個計劃,學習你感興趣的東西應該會有用。這篇文章的主旨就是:你為學習JavaScript 制定的藍圖、路線、行動計劃!你不必擔心找不到最好的資源,先整理些好的資源,再確定下一步該學什么。遵循它,一步一步來。
任務0:了解什么是JavaScript
在你真正開始學習JavaScript 之前,花一分鐘了解一下什么是JavaScript,它有哪些功能。 JavaScript不是jQuery、Flash或Java。與它們不同,它是一種獨立的編程語言。 JavaScript 是瀏覽器語言(盡管現(xiàn)在不完全是)。主要目的是給靜態(tài)頁面增加交互性。在瀏覽器里,它不會為你更換PHP或Ruby,也不會更改你的HTML或CSS;你可以把它們串在一起使用。另外,它沒有你想的那么難學。 補充說明:你應該聽過jQuery,它可能是被使用最廣泛的JavaScript 庫。也許你還聽說過其他比較流行的JavaScript 框架,比如Mootools,,YUI,Dojo 等等。可以將它們統(tǒng)一看做JavaScript輔助工具集;當你使用它們的時候,你還在寫JavaScript,但都是些很抽象的JavaScript。它會讓你事半功倍。 “你甚至可能聽到有人說,你應該先學jQuery(或其他庫)再學JavaScript。我很尊重他們但完全不同意這種說法。先把JavaScript 學好再用其他庫,你會發(fā)現(xiàn)你會做的更好;結果就是,你會編寫更好的JavaScript。”
任務1:通過Codecademy.com站點的課程來學習
Codecademy是一個相對較新的網(wǎng)站,其廣告語是“最易學的編碼方法”。目前,該網(wǎng)站僅有兩個課程,“初級編程”和“JavaScript快速入門指南”。沉浸在JavaScript 中是種不錯的體驗。跟 Try Ruby 練習非常相似,你會學到簡短的課程、在瀏覽器里編碼,然后看結果。得到全部分數(shù)、打開成就徽章。(Ruby,一種為簡單快捷的面向?qū)ο缶幊?面向?qū)ο蟪绦蛟O計)而創(chuàng)的腳本語言。) 如果你已熟悉了另一種編程語言,你也許可以先學“JavaScript快速入門指南”;如果這是您第一次編程(HTML和CSS除外),你會發(fā)現(xiàn)“初級編程”課程相當有用。Codecademy是一家免費網(wǎng)站,但需要注冊。
任務2:appendTo 截屏方法
appendTo 視頻有一套特別適合初學者的截屏方法。 如果你想用正確(容易)的方法學習JavaScript,學習這些課程絕對管用。視覺訓練總是有效的! “用我們提供的點播內(nèi)容、務實的訓練解決方案來提升自己的技能。無需注冊、無需綁定、絕不忽悠?!?/p>
任務3:閱讀一本好的關于JavaScript 的說明書
一旦你通過Codecademy上的課程來學習,你就會想搞到一本關于JavaScript的詳細說明書–介紹所有的類型、運算符、控件架構等等。 如果可以的話,我來介紹幾個好的說明書: 《再說JavaScript》 – 這本說明書可在Mozilla開發(fā)者網(wǎng)絡上找到,語言公正。這本書內(nèi)容很豐富,有很多代碼實例和文段介紹。 《Eloquent JavaScript》 – 該書由Marijn Haverbeke 編寫,可免費在線閱讀,如果你想弄個硬拷貝可以上亞馬遜網(wǎng)站購買。它比MDN說明更詳細,因為它不僅涵蓋了JavaScript 語言,而且包括編碼風格以及在瀏覽器里使用JavaScript。當然,“eloquent”并非言過其實。(eloquent - 雄辯的、口若懸河的) 《Getting Good with JavaScript》 – 沒錯,這本書是我寫的,但是我介紹這本書是另有原因的。它跟我在前面介紹的兩本說明不同;在這本書里我只介紹了編程人員快速掌握編程技巧所需要的部分。此外,它還附帶超過6個小時的截屏視頻,因此,想要就去看看吧。(當然,這本不是免費的。)
任務4:安裝、學習Firebug(或開發(fā)人員工具)
一旦你開始在瀏覽器里使用JavaScript,就需要安裝Firebug并熟悉它的性能。Firebug是一款用于Firefox的插件,它能幫你創(chuàng)建和調(diào)試網(wǎng)頁:對網(wǎng)頁開發(fā)者來說,它就像外科醫(yī)生的‘手術刀'。如果你不用Firefox?喜歡Safari 或者Chrome怎么辦?沒問題:可以查找類似Firebug的內(nèi)置開發(fā)人員工具。 “你可以在Mac地址欄里按選項+命令+I 或者按快捷鍵Control + Shift + I ,來打開設計工具面板?!?通過打開你選的工具,只需在你喜歡的其中一個網(wǎng)站上點擊點擊,你就會學到很多東西。這里有一些能加速你學習的資源:FirebugFirebug網(wǎng)站和維基百科Firebug的CSS-技巧說明你應該在Nettuts+上使用Firebug的10大理由。Firebug:從白帶到黑帶,Tuts+ Marketplace 網(wǎng)站()設計工具設計工具網(wǎng)站Google I/O 2011:由Paul Irish重組的瀏覽器設計工具Google 瀏覽器設計工具:Paul Irish 的快速開發(fā)12技巧
任務5:讀一本有關JavaScript的書籍
現(xiàn)在你已經(jīng)熟悉了些基礎知識,但是還有很多東西要學。盡管我推薦的一些書可能會讓你‘破產(chǎn)',但你會發(fā)現(xiàn)任何時候我都會推薦4本高質(zhì)量的書:
前兩本是一般的、較深入的JavaScript 資源,它們會讓你從簡介到較深層次逐步理解;當然,簡介里會有一些重疊的說明,但不多:剛好讓你看起來很舒服。(注:雖然這些書在亞馬遜網(wǎng)站能買到,我已經(jīng)鏈接了出版商的網(wǎng)站,因此,你能看看范例章節(jié)。) 《JavaScript高級程序設計》- Nicolas C. Zakas 編寫,這本書涵蓋了它能涵蓋的所有內(nèi)容。如果你以前看過Zakas的任何作品,你會發(fā)現(xiàn)他是個不折不扣的天才。除了涵蓋了JavaScript語言,這本書還能讓您在瀏覽器里很好的使用JavaScript。 《JavaScript 24-hour Trainer 》由Jeremy McPeak 編撰,該作者也寫過Nettuts+。它不僅僅是一本書:還附帶了一張長達四小時的教學光碟。全書共43節(jié)課,涉及編碼句法指導和代碼優(yōu)化。 雖然這些書非常適合編程人員學習JavaScript語言以及如何在瀏覽器中使用這些語言,但是學無止境。雖然這些書的確進入了一些模式和實練中,我再推薦兩本我認為有用的書。1)《JavaScript Patterns 》- Stoyan Stefanov著。我也是剛剛讀完這本書,我真希望能盡快讀完它。在讀過上面的資源之后,你可以學到如何編寫JavaScript,但是這本書會教你如何對資源進行重組,這項技能很重要,并非如你想象般簡單。2)《JavaScript:The Good Parts 》- Douglas Crockford 著。該書介紹了JavaScript的優(yōu)缺點。
任務6:做些事情!
在學習完上述資源后,你應該已經(jīng)嘗試了一些代碼樣本:修改代碼、整合代碼看看會怎么樣。但是是時候讓自己休息一下,做點東西出來了。 你能做什么呢?你能做很多東西。這里有一些意見。1) 圖片庫:顯示一套圖片縮略圖和主圖。當用戶點擊縮略圖的時候,要用較大的縮略圖(不是原縮略圖)替代當前的主圖。如果你能覆蓋縮略圖alt 標記的標題就獎勵積分,或是在用戶一分鐘內(nèi)未點擊的時候進行圖片循環(huán)。2) 待辦列表:聽起來有點難,我也不打算推薦你制作一個完整的待辦列表。只需要做一個文本框并在其旁放上按鈕;點擊按鈕的時候,已輸入的文字會在一個無序列表下面變成一個項目。點擊列表項目便可移除。這聽起來很容易,但有幾個陷阱,對初學者來說仔細想想還是很有好處的。3) 動畫框:動畫其實是小把戲而已,并不需要弄得太復雜。做一個包含了少許文本的div,其上要有若干按鈕。一個按鈕用來調(diào)整寬度,一個用來調(diào)整高度;還有一個用來調(diào)整背景顏色。關鍵是不要讓更改發(fā)生得太快,但在一秒鐘之內(nèi)。記住,Google 是你的朋友,特別是如果迄今為止你還未用JavaScript做任何動畫的話。 我相信你能想到其他的很好的練習的計劃。當然,學習的唯一方法是把自己從安樂窩里拽出來?!按送猓谒械募寄芩缴?,確保JavaScript 類別在Nettuts+上有大量教程列表。”(Nettuts是一個專注于提供網(wǎng)絡開發(fā)教程的網(wǎng)站。)
任務7:開始學習如何使用JavaScript庫
如果你學到了這個地步,就會意識到有些JavaScript 編寫任務很難(或根本不能)通過跨瀏覽器的方式實現(xiàn)。最可能違規(guī)的便是過量的DOM操作,AJAX和動畫。這也就是為什么我們需要JavaScript 庫的原因。 正如我前面提到的,一個JavaScript 庫的詳細內(nèi)容猶如減輕痛苦的蜜糖。因此,現(xiàn)在有必要來看一下。這里有大量庫供你選擇,我會讓你自己決定從哪個開始。無論是jQuery 還是Mootools,YUI 還是Dojo,它們各自的網(wǎng)站會為你提供開始學習時你所需要的一切信息。如果你覺得用得著就來試試吧。 最流行的庫: 雖然很容易得到大量的庫,你還是應該選一個受歡迎的– 至少排名第一。 jQuery Dojo YUI MooTools Prototype
任務8:緊隨大師的步伐
有很多令人難以置信的JavaScript 天才,他們一直在做些很酷的東西,你一定不想錯過。值得慶幸的是,我們的工作狂Siddharth 副主編已經(jīng)搞到一份33名設計人員列表,要想成為一名JavaScript 發(fā)燒友你就必須訂閱它。扔下手頭的工作,訂閱/跟隨這些設計人員。這是必須要做的。 但是,你還能做更多事情。這個公平網(wǎng)站經(jīng)常發(fā)布關于JavaScript 的信息,所以不要走開。此外,關注JavaScript Show ,一檔全世界關于JavaScript最新最大的播客。你可能還想注冊JavaScript電子周刊簡訊。 還想要更多嗎?關注Tuts+Marketplace 的JavaScript 類。