自從接觸網(wǎng)站開(kāi)發(fā)以來(lái)到現(xiàn)在已經(jīng)有六個(gè)年頭了,今天偶然整理電腦資料看到當(dāng)時(shí)為參加系里面一個(gè)比賽而做的*個(gè)網(wǎng)站時(shí),勾起了在這網(wǎng)站開(kāi)發(fā)道路上的一串串回憶,成功與喜悅、煩惱與糾結(jié)都?xì)v歷在目,感慨頗多。在此與大家分享,希望對(duì)初學(xué)Web前端的各位童鞋來(lái)說(shuō)有所幫助。歡迎各位吐槽、拍磚。
先從大家學(xué)習(xí)上的一個(gè)誤區(qū)開(kāi)始談起。
前端開(kāi)發(fā)是一個(gè)近幾年興起的新興行業(yè),所以遠(yuǎn)沒(méi)有電子商務(wù)那樣成熟的課程體系,*內(nèi)也沒(méi)有完整的前端課程體系,所以學(xué)習(xí)前端在國(guó)內(nèi)無(wú)非就是培訓(xùn),以及自學(xué)。
培訓(xùn)是針對(duì)那些有條件的人來(lái)說(shuō),很多小伙伴更喜歡的是自學(xué)。但是一個(gè)人自學(xué)畢竟力量是有限的,為了讓想學(xué)習(xí)的人可以更好的學(xué)習(xí),給大家推薦一個(gè)裙,前面是6 1 1,中間是肆 二 8,*面就是壹 四 ?二,這里有很多想學(xué)習(xí)的人和你一起交流,也有大牛每天晚上免費(fèi)教學(xué),想要學(xué)習(xí)的人都可以加入我們,但是我們只歡迎想學(xué)習(xí)的人,不是來(lái)學(xué)習(xí),隨便看看的就不要進(jìn)了。
Web前端的學(xué)習(xí)誤區(qū)
網(wǎng)頁(yè)制作是計(jì)算機(jī)專(zhuān)業(yè)同學(xué)在*期間都會(huì)接觸到的一門(mén)課程,而學(xué)習(xí)網(wǎng)頁(yè)制作所用的*個(gè)集成開(kāi)發(fā)環(huán)境(IDE)想必大多是,這種所見(jiàn)即所得的“吊炸天”IDE為我們制作網(wǎng)頁(yè)帶來(lái)了極大的方便。
入門(mén)快、見(jiàn)效快讓我們?cè)诓恢挥X(jué)中已經(jīng)深深?lèi)?ài)上了網(wǎng)頁(yè)制作。此時(shí),很多人會(huì)陷入一個(gè)誤區(qū),那就是既然借助這么帥的IDE,通過(guò)鼠標(biāo)點(diǎn)擊菜單就可以快速方便地制作網(wǎng)頁(yè)。
那么我們?yōu)槭裁催€要去學(xué)習(xí)HTML、CSS、JavaScrpt、jQuery等這些苦逼的代碼呢?這不是舍簡(jiǎn)求繁嗎?
但是隨著學(xué)習(xí)的深入,就會(huì)發(fā)現(xiàn)我們步入了一種窘境——過(guò)分的依賴(lài)IDE導(dǎo)致我們不清楚其實(shí)現(xiàn)的本質(zhì),知其然但不知其所以然。
因此在頁(yè)面效果出現(xiàn)問(wèn)題時(shí),我們便手足無(wú)措,更不用提如何進(jìn)行頁(yè)面優(yōu)化以及完成一些更高級(jí)的應(yīng)用了。其原因是顯而易見(jiàn)的——聰明的IDE成全了我們的惰性,使我們忽略了華麗的網(wǎng)頁(yè)背后最本質(zhì)的內(nèi)容——code。
正確的方向勝過(guò)無(wú)謂的努力
有兩只螞蟻想翻越一段墻,尋找墻那頭的食物。一只螞蟻來(lái)到墻腳就毫不猶豫地向上爬去,可是每當(dāng)它爬到大半時(shí),就會(huì)由于勞累、疲倦而跌落下來(lái)。雖然它不氣餒,一次次跌下來(lái),又迅速地調(diào)整一下自己,重新開(kāi)始向上爬去?!?/p>
另一只螞蟻觀察了一下,決定繞過(guò)墻去。很快,這只螞蟻繞過(guò)墻來(lái)到食物前,開(kāi)始享受起來(lái);而另一只螞蟻還在不停地跌落下去又重新開(kāi)始。
很多時(shí)候,成功除了勇氣、堅(jiān)持不懈外,更需要方向。也許有了一個(gè)好的方向,成功來(lái)得比想象的更快。如果在錯(cuò)誤的路上奔跑,再怎么努力也是白搭。學(xué)習(xí)Web前端也是如此,首先應(yīng)該選擇一個(gè)正確的學(xué)習(xí)路線(xiàn)。
Web前端的學(xué)習(xí)路線(xiàn)結(jié)合我的學(xué)習(xí)經(jīng)歷、近年來(lái)輔導(dǎo)學(xué)生的經(jīng)驗(yàn)以及公司中實(shí)際項(xiàng)目的需求,在這里將Web前端的學(xué)習(xí)分為以下幾個(gè)階段
*階段——HTML的學(xué)習(xí)?!?/p>
超文本標(biāo)記語(yǔ)言(HyperText Mark-up Language 簡(jiǎn)稱(chēng)HTML)是一個(gè)網(wǎng)頁(yè)的骨架,無(wú)論是靜態(tài)網(wǎng)頁(yè)還是動(dòng)態(tài)網(wǎng)頁(yè),最終返回到瀏覽器端的都是HTML代碼,瀏覽器將HTML代碼解釋渲染后呈現(xiàn)給用戶(hù)。因此,我們必須掌握HTML的基本結(jié)構(gòu)和常用標(biāo)記及屬性。
HTML的學(xué)習(xí)是一個(gè)記憶和理解的過(guò)程,在學(xué)習(xí)過(guò)程中可以借助的“拆分”視圖輔助學(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的縮寫(xiě),叫做層疊樣式表,是能夠真正做到網(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è)完成之后,我們可以交給用戶(hù)使用,但是如果想讓用戶(hù)獲得更佳的體驗(yàn),我們還可以對(duì)“樓房”進(jìn)行更深一步的“裝修”,讓它看起來(lái)更“豪華”一些。
為了完成這個(gè)任務(wù),我們進(jìn)入第三個(gè)階段——的學(xué)習(xí)。
是一種在客戶(hù)端廣泛使用的腳步語(yǔ)言,在當(dāng)中為我們提供了一些內(nèi)置函數(shù)、對(duì)象和DOM操作,借助這些內(nèi)容我們可以來(lái)實(shí)現(xiàn)一些客戶(hù)端的特效、驗(yàn)證、交互等,使我們的頁(yè)面看起來(lái)不那么呆板,屌絲瞬間逆襲高富帥!有么有?
此時(shí),也許你還沉浸在給你帶來(lái)的驚喜之中,但你的項(xiàng)目經(jīng)理卻突然對(duì)你大吼道:
“這個(gè)效果在××瀏覽器下不兼容,重新搞……”
“不兼容?”瞬間石化了有木有?
“我擦,坑爹啊!那可是花了我一個(gè)晚上寫(xiě)了幾百行代碼搞定的啊,吐血了都!”
的兼容性和復(fù)雜性有時(shí)候的確讓我們頭疼,還好有“大神”幫我們做了封裝。
接下來(lái)我們進(jìn)入第四個(gè)階段——jQUery的學(xué)習(xí)。
jQuery是一個(gè)免費(fèi)、開(kāi)源的輕量級(jí)的庫(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上的熱門(mén)開(kāi)源項(xiàng)目。
在項(xiàng)目開(kāi)發(fā)過(guò)程中,我們可以借助Bootstrap提供的CSS樣式、組件、插件等快速的完成頁(yè)面布局和樣式設(shè)置,然后再有針對(duì)性的微調(diào)樣式,這樣基于框架進(jìn)行開(kāi)發(fā)大大縮短了開(kāi)發(fā)周期。站在巨人的肩膀上就是爽!
Web前端的學(xué)習(xí)建議
*給大家聊聊在學(xué)習(xí)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)上說(shuō)自學(xué)沒(méi)啥用,培訓(xùn)也很坑的,都是站在自己的角度上來(lái)說(shuō)的。
自學(xué)真的好嗎?很多時(shí)候我們認(rèn)為自己真的能靠自學(xué)來(lái)學(xué)習(xí)一門(mén)技術(shù),但是又有多少人真的是靠自學(xué)而來(lái)的呢?如果現(xiàn)在學(xué)習(xí)web前端,靠自己看視頻、看書(shū),得需要付出多少的努力才能達(dá)到想要的效果呢?并且有了問(wèn)題也不能及時(shí)去解決,這時(shí)候適合自學(xué)、不適合自學(xué)就都知道了。
適合自學(xué)的人會(huì)想方設(shè)法去解決問(wèn)題,而不適合自學(xué)的人,可能就會(huì)犯懶,直接的把問(wèn)題擱置起來(lái)。并且自學(xué)真的很考驗(yàn)自制力,自制力不好的人真的不適合自學(xué),因?yàn)檎T惑太大了!其實(shí),在大家想要學(xué)習(xí)的時(shí)候,都會(huì)有疑問(wèn):自學(xué)好?培訓(xùn)好?今天就這個(gè)問(wèn)題分析一下。
培訓(xùn)機(jī)構(gòu)學(xué)習(xí)優(yōu)勢(shì):學(xué)習(xí)時(shí)間花費(fèi)相對(duì)來(lái)說(shuō),較短。自學(xué)時(shí)間會(huì)長(zhǎng)一點(diǎn),因?yàn)樽钥亓κ裁吹亩际欠浅?简?yàn)的。講師授課,可以隨時(shí)請(qǐng)教老師,遇到問(wèn)題能及時(shí)解決,技術(shù)提升也會(huì)很快。系統(tǒng)的學(xué)習(xí)web前端知識(shí)。一般培訓(xùn)都會(huì)有系統(tǒng)的課程,根據(jù)課程安排每天的學(xué)習(xí),學(xué)習(xí)的內(nèi)容很全面;管理嚴(yán),培訓(xùn)機(jī)構(gòu)管理很?chē)?yán);有伙伴,做起事情來(lái)更好,因?yàn)樾』锇榈南嗷ス膭?lì),共同探討,不僅能讓你收獲一批朋友,還對(duì)學(xué)習(xí)有很大的幫助!
自主學(xué)習(xí)優(yōu)勢(shì):自主學(xué)習(xí)成本相對(duì)來(lái)說(shuō)較低,可以從網(wǎng)上找到相關(guān)的書(shū)籍、視頻進(jìn)行學(xué)習(xí)。鍛煉自己,能從生活總鍛煉自己自主的能力、控制力、協(xié)調(diào)力,對(duì)自身有一個(gè)很大的提高。學(xué)習(xí)內(nèi)容會(huì)很深刻,自己一步一步學(xué)來(lái)的,很多知識(shí)會(huì)牢牢記住在腦海中。
如果你是零基礎(chǔ)初學(xué)者的話(huà),建議你先自學(xué)一下前端的基礎(chǔ)知識(shí),然后考慮報(bào)一個(gè)培訓(xùn)班,因?yàn)榕嘤?xùn)班的課程速度較快,內(nèi)容很緊湊,如果你沒(méi)有一點(diǎn)基礎(chǔ)知識(shí),很難跟上老師講課的速度。
零基礎(chǔ)學(xué)前端的話(huà),這些書(shū)籍資料可以參考一下:1、《高級(jí)程序設(shè)計(jì)(第3版) 紅皮書(shū) 》,適合有一定編程經(jīng)驗(yàn)的Web應(yīng)用開(kāi)發(fā)人員閱讀,也可作為高校及社會(huì)實(shí)用技術(shù)培訓(xùn)相關(guān)專(zhuān)業(yè)課程的教材。
2、《權(quán)威指南(第6版)》 犀牛書(shū),本書(shū)不僅適合初學(xué)者系統(tǒng)學(xué)習(xí),也適合有經(jīng)驗(yàn)的 開(kāi)發(fā)者隨手翻閱。
3、《
DOM編程藝術(shù)
(第2版)》,本書(shū)在簡(jiǎn)潔明快地講述和DOM的基本知識(shí)之后,通過(guò)幾個(gè)實(shí)例演示了專(zhuān)業(yè)水準(zhǔn)的網(wǎng)頁(yè)開(kāi)發(fā)技術(shù),透徹闡述了平穩(wěn)退化等一批至關(guān)重要的
編程原則和*實(shí)踐,并全面探討了HTML5以及jQuery等庫(kù)。
4、《CSS權(quán)威指南(第三版)》,不管你是一個(gè)有經(jīng)驗(yàn)的Web開(kāi)發(fā)人員還是一個(gè)徹底的初學(xué)者,《CSS權(quán)威指南(第3版)》都是你的CSS學(xué)習(xí)源泉。
5、《設(shè)計(jì)模式》,適合初學(xué)者、前端設(shè)計(jì)者、程序員學(xué)習(xí),也可以作為大專(zhuān)院校相關(guān)專(zhuān)業(yè)師生的學(xué)習(xí)用書(shū),以及培訓(xùn)學(xué)校的教材。
6、《你不知道的(上中下卷) 》,本書(shū)既適合語(yǔ)言初學(xué)者了解其精髓,又適合經(jīng)驗(yàn)豐富的開(kāi)發(fā)人員深入學(xué)習(xí)。
7、《Vue.js權(quán)威指南》,該書(shū)內(nèi)容全面,講解細(xì)致,實(shí)例豐富,適用于各層次的開(kāi)發(fā)者。
學(xué)習(xí)路線(xiàn):第1階段:前端頁(yè)面重構(gòu)(4周)
內(nèi)容包含了:(PC端網(wǎng)站布局項(xiàng)目、HTML5+CSS3基礎(chǔ)項(xiàng)目、WebApp頁(yè)面布局項(xiàng)目)
第2階段:高級(jí)程序設(shè)計(jì)(5周)
內(nèi)容包含:(原生交互功能開(kāi)發(fā)項(xiàng)目、面向?qū)ο筮M(jìn)階與ES5/ES6應(yīng)用項(xiàng)目、工具庫(kù)自主研發(fā)項(xiàng)目)
第3階段:PC端全棧項(xiàng)目開(kāi)發(fā)(3周)
內(nèi)容包含:(jQuery經(jīng)典交互特效開(kāi)發(fā)、HTTP協(xié)議、Ajax進(jìn)階與PHP/JAVA開(kāi)發(fā)項(xiàng)目、前端工程化與模塊化應(yīng)用項(xiàng)目、PC端網(wǎng)站開(kāi)發(fā)項(xiàng)目、PC端管理信息系統(tǒng)前端開(kāi)發(fā)項(xiàng)目)
第4階段:移動(dòng)端項(xiàng)目開(kāi)發(fā)(6周)
內(nèi)容包含:(Touch端項(xiàng)目、微信場(chǎng)景項(xiàng)目、應(yīng)用Angular+Ionic開(kāi)發(fā)WebApp項(xiàng)目、應(yīng)用Vue.js開(kāi)發(fā)WebApp項(xiàng)目、應(yīng)用React.js開(kāi)發(fā)WebApp項(xiàng)目)
第5階段:混合(Hybrid,)開(kāi)發(fā)(1周)
內(nèi)容包含:(微信小程序開(kāi)發(fā)、、各類(lèi)混合應(yīng)用開(kāi)發(fā))
第6階段:NodeJS全棧開(kāi)發(fā)(1周)
內(nèi)容包括:(WebApp后端系統(tǒng)開(kāi)發(fā)、一、NodeJS基礎(chǔ)與NodeJS核心模塊二、Express三、noSQL數(shù)據(jù)庫(kù))
視頻教程可前往B站搜索尚學(xué)堂官方號(hào),免費(fèi)教程隨你挑!一、學(xué)好HTML
HTML(超文本標(biāo)記語(yǔ)言)是網(wǎng)頁(yè)的核心,因此首先應(yīng)該學(xué)好它,不要害怕,HTML很容易學(xué)習(xí)的,但也很容易誤用,學(xué)懂容易要學(xué)精還得費(fèi)點(diǎn)功夫,但學(xué)好HTML是成為Web開(kāi)發(fā)人員的基本條件。(育知同創(chuàng)教育編者注:隨著HTML5規(guī)范出爐日期將近,了解HTML5也將成為Web開(kāi)發(fā)人員的必修課)
二、學(xué)好服務(wù)器端腳本語(yǔ)言
服務(wù)器端腳本編程也是Web開(kāi)發(fā)人員的基本功之一,你只需挑選一個(gè)服務(wù)器端腳本語(yǔ)言,然后學(xué)好它。
三、學(xué)好SQL
要構(gòu)建動(dòng)態(tài)頁(yè)面就必須使用到數(shù)據(jù)庫(kù),但這么多數(shù)據(jù)庫(kù)產(chǎn)品,該如何是好呢?別擔(dān)心,它們都會(huì)遵循標(biāo)準(zhǔn)的SQL原則。
四、學(xué)好CSS
涉及到網(wǎng)頁(yè)外觀時(shí),就需要學(xué)習(xí)CSS了,它可以幫你把網(wǎng)頁(yè)做得更美觀。
五、學(xué)好
今天大部分Web開(kāi)發(fā)人員都喜歡使用jQuery,學(xué)習(xí)的基本語(yǔ)法,以及如何使用編程將會(huì)提高你的技能。
六、學(xué)好正則表達(dá)式
雖然它并不像其它知識(shí)那么重要,但學(xué)習(xí)了正則表達(dá)式后,如果使用得當(dāng)將會(huì)節(jié)省你很多時(shí)間,從驗(yàn)證到高亮顯示它夠能幫到你。
七、學(xué)習(xí)一點(diǎn)Unix和Linux的基本知識(shí)
這并不是必須的,但知道一點(diǎn)Linux命令不會(huì)傷害到你,或許你還不知道,大部分Web服務(wù)器都運(yùn)行在Unix和Linux平臺(tái)上,如果我是你,我會(huì)去學(xué)習(xí)一些基本的Linux命令的。
八、了解Web服務(wù)器
你不必在這上面花太多精力,但對(duì)Apache的基本配置,.htaccess配置技巧有一些掌握的話(huà),將來(lái)必定受益,而且這方面的知識(shí)學(xué)起來(lái)也相對(duì)容易,不會(huì)花多長(zhǎng)時(shí)間。
九、熟悉版本控制系統(tǒng)的用法
熟悉使用一種優(yōu)秀的版本控制系統(tǒng)將很有用處,你在實(shí)際工作中就會(huì)發(fā)現(xiàn)精通一種版本控制系統(tǒng)是多么幸福。
十、學(xué)好Web框架
當(dāng)你掌握了HTML,服務(wù)器端腳本語(yǔ)言,CSS和后,就應(yīng)該找一個(gè)Web框架加快你的Web開(kāi)發(fā)速度,使用框架可以節(jié)約你很多時(shí)間,如果你使用PHP,可選的框架有CakePHP,,Zend等,Python程序員喜歡使用Django和webpy,Ruby程序員喜歡使用RoR。
只要一個(gè)電話(huà)
我們免費(fèi)為您回電