前端處于一個(gè)高速發(fā)展的時(shí)代。回望前端的發(fā)展,在過(guò)去十年中,前端從簡(jiǎn)陋的HTML,CSS,JavaScript三把刷子做出來(lái)靜態(tài)網(wǎng)頁(yè)的時(shí)代,發(fā)展到現(xiàn)在視覺(jué)效果酷炫,適用終端廣泛,開(kāi)發(fā)手段豐富多樣的前所未有的黃金時(shí)代。
越來(lái)越多的開(kāi)發(fā)者涌入前端行業(yè)淘金,那么就有一種說(shuō)法流傳出來(lái),“前端開(kāi)發(fā)已經(jīng)飽和了”,“前端開(kāi)發(fā)要找不到工作了”。這是不是在危言聳聽(tīng),真相是什么樣的呢?在多個(gè)招聘網(wǎng)站搜索“前端工程師”職位就會(huì)發(fā)現(xiàn),在每個(gè)一線城市均可找到10000+以上前端工程師招聘職位。對(duì)前端開(kāi)發(fā)需求量依然可以保證你找到一門工作,不存在飽和這樣的說(shuō)法。
但如果你再仔細(xì)留意,你會(huì)發(fā)現(xiàn)招聘量最大的3-5年的中高級(jí)前端乃至前端架構(gòu)師,而不是初級(jí)前端。所以再回過(guò)頭來(lái)說(shuō)前端飽不飽和這個(gè)問(wèn)題,需求肯定是不飽和,但留給初級(jí)前端的機(jī)會(huì)確實(shí)少了。
所以,如果你是一個(gè)實(shí)力很弱的前端小菜鳥,找到一份心儀的前端工作是有些困難的,初級(jí)前端就只能失業(yè)了嗎?不,除了熬年限、熬經(jīng)驗(yàn),實(shí)力才是最為重要的。高水平的開(kāi)發(fā)也是從初級(jí)水平成長(zhǎng)起來(lái)的,你也是可以成長(zhǎng)為一名高級(jí)前端開(kāi)發(fā)的。
初級(jí)開(kāi)發(fā)怎么才能成長(zhǎng)為一名高級(jí)前端?前端的知識(shí)體系龐雜,框架、庫(kù)、插件數(shù)不勝數(shù),小白學(xué)習(xí)web前端開(kāi)發(fā)應(yīng)該學(xué)習(xí)哪些東西?
1夯實(shí)基礎(chǔ)
前端的基礎(chǔ)是什么?是HTML、CSS,JavaScript。特別是JavaScript,我們對(duì)前端基礎(chǔ)的掌握程度,極大程度上體現(xiàn)在對(duì)JavaScript的掌握程度上。所有的瀏覽器引擎運(yùn)行的腳本語(yǔ)言都是JavaScript,我們使用的框架也是用JavaScript開(kāi)發(fā)的。即使最近非常流行的typescript,其實(shí)底層也是JavaScript,是需要編譯為JavaScript后才能在瀏覽器運(yùn)行的。即使是高級(jí)前端工程師的面試中,對(duì)于JavaScript知識(shí)的考核也是必不可少的。不僅體現(xiàn)在JavaScript語(yǔ)法,API,也很大一部分包含著最新的ES6的知識(shí)。
2主動(dòng)學(xué)習(xí)
一名優(yōu)秀的程序員絕對(duì)不是一個(gè)被別人牽著鼻子或者被人用鞭子趕著才會(huì)去學(xué)習(xí)的人,他一定是一個(gè)主動(dòng)學(xué)習(xí)的人。優(yōu)秀的程序員之所以優(yōu)秀,是因?yàn)樗猩詈竦闹R(shí)積累,而這些知識(shí)的來(lái)源,是因?yàn)樗诓粩嗟貙W(xué)習(xí)。所以才能夠在工作中解決棘手的問(wèn)題,在面試中回答出刁鉆的難題,因此而獲得豐厚的薪水。一個(gè)被動(dòng)學(xué)習(xí)的人,我想是很難達(dá)到這種地步的。
作為前端要主動(dòng)學(xué)習(xí),方向必須是能夠具有針對(duì)性的提升自身競(jìng)爭(zhēng)力的內(nèi)容,而且是輕易不會(huì)過(guò)時(shí)的穩(wěn)定的知識(shí)。比如就像語(yǔ)言內(nèi)部機(jī)制和框架原理,設(shè)計(jì)模式這種知識(shí)。學(xué)了這種知識(shí),其實(shí)就有能力自己做一些簡(jiǎn)單的框架,工具和庫(kù)了,心中有底氣,就可以擺脫被不斷更新的應(yīng)用型,API型知識(shí)牽著鼻子走的局面。
新手學(xué)習(xí)前端開(kāi)發(fā)的話,一般需要5到8個(gè)月的時(shí)間。
如何學(xué)習(xí)前端開(kāi)發(fā),
Web前端的學(xué)習(xí)路線
結(jié)合我的學(xué)習(xí)經(jīng)歷、近年來(lái)輔導(dǎo)學(xué)生的經(jīng)驗(yàn)以及公司中實(shí)際項(xiàng)目的需求,在這里將Web前端的學(xué)習(xí)分為以下幾個(gè)階段,具體的學(xué)習(xí)路線圖如圖所示。
第一階段——HTML的學(xué)習(xí)。
超文本標(biāo)記語(yǔ)言(HyperText Mark-up Language 簡(jiǎn)稱HTML)是一個(gè)網(wǎng)頁(yè)的骨架,無(wú)論是靜態(tài)網(wǎng)頁(yè)還是動(dòng)態(tài)網(wǎng)頁(yè),最終返回到瀏覽器端的都是HTML代碼,瀏覽器將HTML代碼解釋渲染后呈現(xiàn)給用戶。因此,我們必須掌握HTML的基本結(jié)構(gòu)和常用標(biāo)記及屬性。
HTML的學(xué)習(xí)是一個(gè)記憶和理解的過(guò)程,在學(xué)習(xí)過(guò)程中可以借助Dreamweaver的“拆分”視圖輔助學(xué)習(xí)。在“設(shè)計(jì)”視圖中看效果,在“代碼”視圖中學(xué)本質(zhì),將各種視圖的優(yōu)勢(shì)發(fā)揮到極致,這種對(duì)照學(xué)習(xí)的方法彌補(bǔ)了單純識(shí)記HTML標(biāo)簽和屬性的枯燥乏味,想必對(duì)各位初學(xué)的小盆友們來(lái)說(shuō)必定是極好的!
在學(xué)習(xí)了HTML之后,我們只是掌握了各種“原材料”的制作方法,要想蓋一幢樓房就還需要把這些“原材料”按照我們?cè)O(shè)計(jì)的方案組合布局在一起并進(jìn)行一些樣式的美化。
于是進(jìn)入第二個(gè)階段——CSS的學(xué)習(xí)。
CSS是英文Cascading Style Sheets的縮寫,叫做層疊樣式表,是能夠真正做到網(wǎng)頁(yè)表現(xiàn)與內(nèi)容分離的一種樣式設(shè)計(jì)語(yǔ)言。相對(duì)于傳統(tǒng)HTML的表現(xiàn)而言其樣式是可以復(fù)用的,這樣就極大地提高了我們開(kāi)發(fā)的速度,降低了維護(hù)的成本。
同時(shí)CSS中的盒子模型、相對(duì)布局、絕對(duì)布局等能夠?qū)崿F(xiàn)對(duì)網(wǎng)頁(yè)中各對(duì)象的位置排版進(jìn)行像素級(jí)的精確控制。通過(guò)此階段的學(xué)習(xí),我們就可以順利完成“一幢樓房”的建設(shè)。
“樓房”建設(shè)完成之后,我們可以交給用戶使用,但是如果想讓用戶獲得更佳的體驗(yàn),我們還可以對(duì)“樓房”進(jìn)行更深一步的“裝修”,讓它看起來(lái)更“豪華”一些。
為了完成這個(gè)任務(wù),我們進(jìn)入第三個(gè)階段——JavaScript的學(xué)習(xí)。
JavaScript是一種在客戶端廣泛使用的腳步語(yǔ)言,在JavaScript當(dāng)中為我們提供了一些內(nèi)置函數(shù)、對(duì)象和DOM操作,借助這些內(nèi)容我們可以來(lái)實(shí)現(xiàn)一些客戶端的特效、驗(yàn)證、交互等,使我們的頁(yè)面看起來(lái)不那么呆板,屌絲瞬間逆襲高富帥!有么有?
此時(shí),也許你還沉浸在JavaScript給你帶來(lái)的驚喜之中,但你的項(xiàng)目經(jīng)理卻突然對(duì)你大吼道
JavaScript的兼容性和復(fù)雜性有時(shí)候的確讓我們頭疼,還好有“大神”幫我們做了封裝。
接下來(lái)我們進(jìn)入第四個(gè)階段——jQUery的學(xué)習(xí)。
jQuery是一個(gè)免費(fèi)、開(kāi)源的輕量級(jí)的JavaScript庫(kù),并且兼容各種瀏覽器(jQuery2.0及后續(xù)版本放棄了對(duì)IE6/7/8瀏覽器的支持),同時(shí)現(xiàn)在有很多基于jQuery的插件可供選擇,這樣在我們實(shí)現(xiàn)一些豐富的動(dòng)態(tài)效果時(shí)更方便快捷,大大節(jié)省了我們開(kāi)發(fā)的時(shí)間,提高了開(kāi)發(fā)速度,這也充分體現(xiàn)了其write less,do more的核心宗旨。這個(gè)Feel倍兒爽!有么有?
“豪華大樓”至此拔地而起,但是每天這樣日復(fù)一日,年復(fù)一年的蓋樓,好繁瑣!能不能將大樓里面每一個(gè)單獨(dú)部件模塊化,當(dāng)需要蓋樓時(shí)就像堆積木一樣組合在一起,這樣豈不是爽歪歪?可以實(shí)現(xiàn)嗎?答案是肯定的。
這種思想在Web前端開(kāi)發(fā)中也是適合的,于是乎就出現(xiàn)了各種前端框架,在這里推薦給大家的是Bootstrap。
Bootstrap是Twitter推出的一個(gè)開(kāi)源的用于前端開(kāi)發(fā)的工具包,是一個(gè)CSS/HTML框架,并且支持響應(yīng)式布局。一經(jīng)推出后頗受歡迎,一直是GitHub上的熱門開(kāi)源項(xiàng)目。
在項(xiàng)目開(kāi)發(fā)過(guò)程中,我們可以借助Bootstrap提供的CSS樣式、組件、JavaScript插件等快速的完成頁(yè)面布局和樣式設(shè)置,然后再有針對(duì)性的微調(diào)樣式,這樣基于框架進(jìn)行開(kāi)發(fā)大大縮短了開(kāi)發(fā)周期。站在巨人的肩膀上就是爽!
Web前端的學(xué)習(xí)建議
最后給大家聊聊在學(xué)習(xí)Web前端中的一些建議和方法。
自己是一個(gè)五年的全棧工程師,這里推薦一下我的前端學(xué)習(xí)交流群:開(kāi)始484然后757最后760,里面都是學(xué)習(xí)前端的,群里會(huì)不定期更新最新的教程和學(xué)習(xí)方法,有想學(xué)習(xí)web前端的,或是轉(zhuǎn)行,或是大學(xué)生,還有工作中想提升自己能力的web前端黨歡迎加入,
在CSS布局時(shí)需要注意的一個(gè)問(wèn)題是很多同學(xué)缺乏對(duì)頁(yè)面布局進(jìn)行整體分析,不能夠從宏觀上對(duì)頁(yè)面中盒子間的嵌套關(guān)系進(jìn)行把握,就急于動(dòng)手去做,導(dǎo)致頁(yè)面中各元素間的關(guān)系很混亂,容易出現(xiàn)盒子在浮動(dòng)時(shí)錯(cuò)位等情況。建議大家在布局時(shí)采用“自頂向下,逐步細(xì)化”的思想,先用幾個(gè)盒子將頁(yè)面從整體上劃分,然后逐步在盒子中繼續(xù)嵌套盒子。
“君子生非異也,善假于物也”,在學(xué)習(xí)的過(guò)程中還要多瀏覽一些優(yōu)秀的網(wǎng)站,善于分析借鑒其設(shè)計(jì)思路和布局方法,見(jiàn)多方能識(shí)廣,進(jìn)而才可以融會(huì)貫通,取他人之長(zhǎng)為我所用。
同時(shí)還要善于使用Firebug這個(gè)利器。Firebug一方面可以在我們學(xué)習(xí)過(guò)程中幫助我們調(diào)試自己的頁(yè)面,另一方面我們可以使用Firebug方便地查看、分析別人網(wǎng)站的源代碼,“偷”也是一種技能!
隨著移動(dòng)互聯(lián)網(wǎng)熱潮的到來(lái),移動(dòng)開(kāi)發(fā)越來(lái)越受到大家的追捧,響應(yīng)式布局、微網(wǎng)站等需求量不斷增加,也是我們Web前端未來(lái)的發(fā)展方向之一,學(xué)有余力的同學(xué)可以多多關(guān)注。最后祝愿大家能在Web前端開(kāi)發(fā)道路上走出一片更寬更廣的天地!
網(wǎng)頁(yè)前端開(kāi)發(fā)工程師就是與網(wǎng)頁(yè)打交到。下面幾個(gè)技能是必備的。
HTML寫網(wǎng)頁(yè)怎么離得開(kāi)html,html也叫超文本標(biāo)記語(yǔ)言,它包括很多標(biāo)簽。通過(guò)標(biāo)簽對(duì)文字,圖片,聲音,視屏等網(wǎng)頁(yè)元素進(jìn)行格式化處理。html就是網(wǎng)頁(yè)的基礎(chǔ)。
CSSCSS是層疊樣式表的英文簡(jiǎn)稱,CSS能夠?qū)W(wǎng)頁(yè)的元素的位置進(jìn)行排版,那些漂亮的網(wǎng)頁(yè)就是用CSS進(jìn)行排版的,什么元素在什么位置都是通過(guò)CSS進(jìn)行處理的,部分網(wǎng)頁(yè)的動(dòng)態(tài)效果也是用css實(shí)現(xiàn)的,常見(jiàn)的loading樣式,鼠標(biāo)進(jìn)入圖片放大等效果都可以用CSS實(shí)現(xiàn)。網(wǎng)頁(yè)的布局離不開(kāi)CSS。
JavascriptJavaScript簡(jiǎn)稱js,是一款解釋型腳本語(yǔ)言,它對(duì)網(wǎng)頁(yè)的作用就是處理用戶事件的,比如網(wǎng)頁(yè)的元素被點(diǎn)擊后有什么效果,就需要利用js進(jìn)行事件綁定。比如登錄界面,用戶輸入賬號(hào)密碼后點(diǎn)擊登錄。js就會(huì)處理這些事件,去訪問(wèn)后臺(tái)拿到結(jié)果后判斷是否登錄成功。總之,js就是處理事件的。
前端框架前端框架就是對(duì)js的二次封裝,把常用的功能封裝起來(lái),提高開(kāi)發(fā)者的開(kāi)發(fā)效率。
常見(jiàn)的前端框架有jquery:獨(dú)特的鏈?zhǔn)秸Z(yǔ)法和簡(jiǎn)潔的多功能接口;具有高效靈活的css選擇器,并且可對(duì)CSS選擇器進(jìn)行擴(kuò)展。
Bootstrap:讓頁(yè)面更加簡(jiǎn)潔、直觀。是移動(dòng)設(shè)備優(yōu)秀的前端開(kāi)發(fā)框架,讓網(wǎng)頁(yè)開(kāi)發(fā)更迅速、更簡(jiǎn)單。它還提供了優(yōu)雅的HTML和CSS規(guī)范,有著豐富的網(wǎng)格布局系統(tǒng)以及大量的可重用組件,還支持JavaScript、jQuery插件以及組件定制等。
AngularJS:有很多特性,最為核心的是MVW(Model-View-Whatever)、模塊化、自動(dòng)化雙向數(shù)據(jù)綁定、語(yǔ)義化標(biāo)簽、依賴注入等等。
Vue:Vue.js是一個(gè)構(gòu)建數(shù)據(jù)驅(qū)動(dòng)的 web 界面的漸進(jìn)式框架。Vue.js 的目標(biāo)是通過(guò)盡可能簡(jiǎn)單的 API 實(shí)現(xiàn)響應(yīng)的數(shù)據(jù)綁定和組合的視圖組件。
調(diào)試工具網(wǎng)頁(yè)寫好了,總是要看看效果的,這個(gè)時(shí)候調(diào)試工具是必要的,一般都是用瀏覽器進(jìn)行調(diào)試,chrome,F(xiàn)irefox等主流瀏覽器的網(wǎng)頁(yè)調(diào)試方法都要會(huì)。
以上都學(xué)會(huì)了,就需要項(xiàng)目進(jìn)行實(shí)戰(zhàn)了。