前端工程師,也叫Web前端開發(fā)工程師。他是隨著web發(fā)展,細(xì)分出來的行業(yè)。
Web前端開發(fā)技術(shù)主要包括三個要素:HTML、CSS和JavaScript!
它要求前端開發(fā)工程師不僅要掌握基本的Web前端開發(fā)技術(shù),網(wǎng)站性能優(yōu)化、SEO和服務(wù)器端的基礎(chǔ)知識,而且要學(xué)會運用各種工具進行輔助開發(fā)以及理論層面的知識,包括代碼的可維護性、組件的易用性、分層語義模板和瀏覽器分級支持等。
隨著近兩三年來RIA(Rich Internet Applications的縮寫,中文含義為:豐富的因特網(wǎng)應(yīng)用程序)的流行和普及帶來的諸如:Flash/Flex,Silverlight、XML和服務(wù)器端語言(PHP、ASP.NET,JSP、Python)等語言,前端開發(fā)工程師也需要掌握。
前端開發(fā)的入門門檻其實很低,與服務(wù)器端語言先慢后快的學(xué)習(xí)曲線相比,前端開發(fā)的學(xué)習(xí)曲線是先快后慢。
HTML 甚至不是一門語言,他僅僅是簡單的標(biāo)記語言!
CSS 只是無類型的樣式修飾語言。當(dāng)然可以勉強算作弱類型語言。
Javascript 的基礎(chǔ)部分相對來說不難,入手還算快。
也正因為如此,前端開發(fā)領(lǐng)域有很多自學(xué)成“才”的同行,但大多數(shù)人都停留在會用的階段,因為后面的學(xué)習(xí)曲線越來越陡峭,每前進一步都很難。
Web前端技術(shù)有一些江湖氣,知識點過于瑣碎,技術(shù)價值觀的博弈也難分伯仲,即全局的系統(tǒng)的知識結(jié)構(gòu)并未成體系,這些因素也客觀上影響了“正統(tǒng)“前端技術(shù)的沉淀!而且各種“奇技淫巧”被濫用,前端技術(shù)知識的傳承也過于泛泛,新人難看清時局把握主次。因此,前端技術(shù)領(lǐng)域,為自己覓得一個靠譜的師兄,重要性要蓋過項目、團隊、公司、甚至薪水。
另一方面,正如前面所說,前端開發(fā)是個非常新的職業(yè),對一些規(guī)范和最佳實踐的研究都處于探索階段。
總有新的靈感和技術(shù)不時閃現(xiàn)出來,例如CSS sprite、負(fù)邊距布局、柵格布局等;
各種JavaScript框架層出不窮,為整個前端開發(fā)領(lǐng)域注入了巨大的活力;
瀏覽器大戰(zhàn)也越來越白熱化,跨瀏覽器兼容方案依然是五花八門。
為了滿足“高可維護性”的需要,需要更深入、更系統(tǒng)地去掌握前端知識,這樣才可能創(chuàng)建一個好的前端架構(gòu),保證代碼的質(zhì)量。
隨著手持設(shè)備的迅猛發(fā)展,帶動了 HTML5行業(yè)標(biāo)準(zhǔn)的快速發(fā)展。web領(lǐng)域的技術(shù),大概有10年都沒有大的更新了!
現(xiàn)在市場很需要優(yōu)秀的、高級的前端工程師。
一方面是因為這是一個比較新的細(xì)分行業(yè),而且前端程序員大都自學(xué)一部分,知識結(jié)構(gòu)不系統(tǒng);另一方面,大學(xué)里面沒有這種課程,最最重要的是:北大青鳥這類培訓(xùn)機構(gòu)也沒有專門的前端工程師的培訓(xùn)課程??!
吳亮在《JavaScript 王者歸來》第一張的序里面說:大多數(shù)程序員認(rèn)為 Javascript 過于簡陋,只適合一些網(wǎng)頁上面花哨的表現(xiàn),所以不愿花費精力去學(xué)習(xí),或者以為不學(xué)習(xí)就能掌握。
實際上,一門語言是否腳本語言,往往是她的設(shè)計目標(biāo)決定,簡單與復(fù)雜并不是區(qū)分腳本語言和非腳本語言的標(biāo)準(zhǔn)。
事實上,在腳本語言里面,Javascript 屬于相當(dāng)復(fù)雜的一門語言,他的復(fù)雜度即使放在非腳本語言中來衡量,也是一門相當(dāng)復(fù)雜的語言!
Javascript 的復(fù)雜度不遜色于 Perl 和 Python!
如何學(xué)習(xí)前端知識?
我們生活在一個充滿規(guī)則的宇宙里面。社會秩序按照規(guī)則運行,計算機語言幾乎全部是規(guī)則的集合。計算機前輩們定義規(guī)則,規(guī)則約束我們,我們用規(guī)則控制數(shù)據(jù)。大部分時候,對數(shù)據(jù)的合理控制,來自于你對規(guī)則的掌握。
學(xué)習(xí) HTML,CSS 應(yīng)該先跟著書仔細(xì)、扎實的學(xué)一遍。然后就需要做大量的練習(xí),做各種常規(guī)的、奇怪的、大量的布局練習(xí)來捆固、理解自己的知識。
而學(xué)習(xí) Javascript 首先要知道這門語言可以做什么,不能做什么,擅長做什么,不擅長做什么!
如果你只想當(dāng)一個普通的前端程序員,你只需要記住大部分 Javascript 函數(shù),做一些練習(xí)就可以了。
如果你想當(dāng)深入了解Javascript,你需要了解 Javascript 的原理,機制。需要知道他們的本源,需要深刻了解 Javascript 基于對象的本質(zhì)。
還需要 深刻了解 瀏覽器宿主 下 的 Javascript 的行為、特性。
因為歷史原因,Javascript一直不被重視,有點像被收養(yǎng)的一般! 所以他有很多缺點,各個宿主環(huán)境下的行為不統(tǒng)一、內(nèi)存溢出問題、執(zhí)行效率低下等問題。
作為一個優(yōu)秀的前端工程師還需要深入了解、以及學(xué)會處理 Javascript 的這些缺陷。
那么一名優(yōu)秀的、甚至卓越的 前端開發(fā)工程師的具備什么條件?
首先,優(yōu)秀的Web前端開發(fā)工程師要在知識體系上既要有廣度和深度!做到這兩點,其實很難。所以很多大公司即使出高薪也很難招聘到理想的前端開發(fā)工程師。技術(shù)非黑即白,只有對和錯,而技巧則見仁見智。
在以前,會一點Photoshop和Dreamweaver的操作,就可以制作網(wǎng)頁。
現(xiàn)在,只掌握這些已經(jīng)遠(yuǎn)遠(yuǎn)不夠了。無論是開發(fā)難度上,還是開發(fā)方式上,現(xiàn)在的網(wǎng)頁制作都更接近傳統(tǒng)的網(wǎng)站后臺開發(fā),所以現(xiàn)在不再叫網(wǎng)頁制作,而是叫Web前端開發(fā)。
Web前端開發(fā)在產(chǎn)品開發(fā)環(huán)節(jié)中的作用變得越來越重要,而且需要專業(yè)的前端工程師才能做好。
Web前端開發(fā)是一項很特殊的工作,涵蓋的知識面非常廣,既有具體的技術(shù),又有抽象的理念。簡單地說,它的主要職能就是把網(wǎng)站的界面更好地呈現(xiàn)給用戶。
其次,優(yōu)秀的Web前端開發(fā)工程師應(yīng)該具備快速學(xué)習(xí)能力。Web發(fā)展的很快,甚至可以說這些技術(shù)幾乎每天都在變化!如果沒有快速學(xué)習(xí)能力,就跟不上Web發(fā)展的步伐。前端工程師必須不斷提升自己,不斷學(xué)習(xí)新技術(shù)、新模式;僅僅依靠今天的知識無法適應(yīng)未來。Web的明天與今天必將有天壤之別,而前端工程師的工作就是要搞清楚如何通過自己的Web應(yīng)用程序來體現(xiàn)這種翻天覆地的變化。
說到這里,我想起了一個大師說過的一句話:對于新手來說,新技術(shù)就是新技術(shù)。
對于一個高手來說,新技術(shù)不過是就技術(shù)的延伸。
再者,優(yōu)秀的前端工程師需要具備良好的溝通能力,因為前端工程師至少都要滿足四類客戶的需求。
1、產(chǎn)品經(jīng)理。這些是負(fù)責(zé)策劃應(yīng)用程序的一群人。他們會想出很多新鮮的、奇怪的、甚至是不可是實現(xiàn)的應(yīng)用。一般來說,產(chǎn)品經(jīng)理都追求豐富的功能。
2、UI設(shè)計師。這些人負(fù)責(zé)應(yīng)用程序的視覺設(shè)計和交互模擬。他們關(guān)心的是用戶對什么敏感、交互的一貫性以及整體的好用性。一般來說,UI設(shè)計師于流暢靚麗、但并不容易實現(xiàn)的用戶界面,而且他們經(jīng)常不滿前端工程師造成 1px 的誤差。
3、項目經(jīng)理。這些人負(fù)責(zé)實際地運行和維護應(yīng)用程序。項目管理的主要關(guān)注點,無外乎正常運行時間、應(yīng)用程序始終正常可用的時間、性能和截止日期。項目經(jīng)理追求的目標(biāo)往往是盡量保持事情的簡單化,以及不在升級更新時引入新問題。
4、最終用戶。指的是應(yīng)用程序的主要消費者。盡管前端工程師不會經(jīng)常與最終用戶打交道,但他們的反饋意見至關(guān)重要。最終用戶要求最多的就是對個人有用的功能,以及競爭性產(chǎn)品所具備的功能。