首先明,確怎樣才能學(xué)好wbe前端開發(fā):
創(chuàng)新互聯(lián)建站堅持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都網(wǎng)站制作、成都網(wǎng)站設(shè)計、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時代的扎賚特網(wǎng)站設(shè)計、移動媒體設(shè)計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
現(xiàn)在很多人喜歡自學(xué)web前端開發(fā),但是一個人的能力畢竟是有限的,所以我自己建了一個裙,它的前面是4 九 4,中間就是4 〇 6 ,最后就是9 三 4 。歡迎想要學(xué)習(xí)的小伙伴加入我們學(xué)習(xí)哦。如果不是來學(xué)習(xí)的就不要加了,加了也是浪費(fèi)時間。
Web前端的學(xué)習(xí)路線
1.第一階段——HTML的學(xué)習(xí)
超文本標(biāo)記語言(HyperText Mark-up Language 簡稱HTML)是一個網(wǎng)頁的骨架,無論是靜態(tài)網(wǎng)頁還是動態(tài)網(wǎng)頁,最終返回到瀏覽器端的都是HTML代碼,瀏覽器將HTML代碼解釋渲染后呈現(xiàn)給用戶。因此,我們必須掌握HTML的基本結(jié)構(gòu)和常用標(biāo)記及屬性。
HTML 的學(xué)習(xí)是一個記憶和理解的過程,在學(xué)習(xí)過程中可以借助Dreamweaver的“拆分”視圖輔助學(xué)習(xí)。在“設(shè)計”視圖中看效果,在“代碼”視圖中學(xué)本質(zhì),將各種視圖的優(yōu)勢發(fā)揮到極致,這種對照學(xué)習(xí)的方法彌補(bǔ)了單純識記HTML標(biāo)簽和屬性的枯燥乏味,想必對各位初學(xué)的小盆友們來說必定是極好的!
在學(xué)習(xí)了HTML之后,我們只是掌握了各種“原材料”的制作方法,要想蓋一幢樓房就還需要把這些“原材料”按照我們設(shè)計的方案組合布局在一起并進(jìn)行一些樣式的美化。
2.第二個階段——CSS的學(xué)習(xí)
CSS是英文Cascading Style Sheets的縮寫,叫做層疊樣式表,是能夠真正做到網(wǎng)頁表現(xiàn)與內(nèi)容分離的一種樣式設(shè)計語言。相對于傳統(tǒng)HTML的表現(xiàn)而言其樣式是可以復(fù)用的,這樣就極大地提高了我們開發(fā)的速度,降低了維護(hù)的成本。
同時CSS中的盒子模型、相對布局、絕對布局等能夠?qū)崿F(xiàn)對網(wǎng)頁中各對象的位置排版進(jìn)行像素級的精確控制。通過此階段的學(xué)習(xí),我們就可以順利完成“一幢樓房”的建設(shè)。
“樓房”建設(shè)完成之后,我們可以交給用戶使用,但是如果想讓用戶獲得更佳的體驗,我們還可以對“樓房”進(jìn)行更深一步的“裝修”,讓它看起來更“豪華”一些。
3.第三個階段——Java的學(xué)習(xí)
Java是一種在客戶端廣泛使用的腳步語言,在Java當(dāng)中為我們提供了一些內(nèi)置函數(shù)、對象和DOM操作,借助這些內(nèi)容我們可以來實現(xiàn)一些客戶端的特效、驗證、交互等,使我們的頁面看起來不那么呆板,屌絲瞬間逆襲高富帥!有么有?
此時,也許你還沉浸在Java給你帶來的驚喜之中,但你的項目經(jīng)理卻突然對你大吼道
“這個效果在××瀏覽器下不兼容,重新搞……”
“不兼容?”瞬間石化了有木有?
“我擦,坑爹啊!那可是花了我一個晚上寫了幾百行代碼搞定的啊,吐血了都!”
Java的兼容性和復(fù)雜性有時候的確讓我們頭疼,還好有“大神”幫我們做了封裝。
5.第四個階段——jQUery的學(xué)習(xí)
jQuery 是一個免費(fèi)、開源的輕量級的Java庫,并且兼容各種瀏覽器(jQuery2.0及后續(xù)版本放棄了對IE6/7/8瀏覽器的支持),同時現(xiàn)在有很多基于jQuery的插件可供選擇,這樣在我們實現(xiàn)一些豐富的動態(tài)效果時更方便快捷,大大節(jié)省了我們開發(fā)的時間,提高了開發(fā)速度,這也充分體現(xiàn)了其 write less,do more的核心宗旨。這個Feel倍兒爽!有么有?
“豪華大樓”至此拔地而起,但是每天這樣日復(fù)一日,年復(fù)一年的蓋樓,好繁瑣!能不能將大樓里面每一個單獨部件模塊化,當(dāng)需要蓋樓時就像堆積木一樣組合在一起,這樣豈不是爽歪歪?可以實現(xiàn)嗎?答案是肯定的。
這種思想在Web前端開發(fā)中也是適合的,于是乎就出現(xiàn)了各種前端框架,在這里推薦給大家的是Bootstrap。
Bootstrap是Twitter推出的一個開源的用于前端開發(fā)的工具包,是一個CSS/HTML框架,并且支持響應(yīng)式布局。一經(jīng)推出后頗受歡迎,一直是GitHub上的熱門開源項目。
在項目開發(fā)過程中,我們可以借助Bootstrap提供的CSS樣式、組件、Java插件等快速的完成頁面布局和樣式設(shè)置,然后再有針對性的微調(diào)樣式,這樣基于框架進(jìn)行開發(fā)大大縮短了開發(fā)周期。站在巨人的肩膀上就是爽!
Web前端的學(xué)習(xí)建議
最后給大家聊聊在學(xué)習(xí)Web前端中的一些建議和方法。
在CSS布局時需要注意的一個問題是很多同學(xué)缺乏對頁面布局進(jìn)行整體分析,不能夠從宏觀上對頁面中盒子間的嵌套關(guān)系進(jìn)行把握,就急于動手去做,導(dǎo)致頁面中各元素間的關(guān)系很混亂,容易出現(xiàn)盒子在浮動時錯位等情況。建議大家在布局時采用“自頂向下,逐步細(xì)化”的思想,先用幾個盒子將頁面從整體上劃分,然后逐步在盒子中繼續(xù)嵌套盒子。
“君子生非異也,善假于物也”,在學(xué)習(xí)的過程中還要多瀏覽一些優(yōu)秀的網(wǎng)站,善于分析借鑒其設(shè)計思路和布局方法,見多方能識廣,進(jìn)而才可以融會貫通,取他人之長為我所用。
同時還要善于使用Firebug這個利器。Firebug一方面可以在我們學(xué)習(xí)過程中幫助我們調(diào)試自己的頁面,另一方面我們可以使用Firebug方便地查看、分析別人網(wǎng)站的源代碼,“偷”也是一種技能!
每個人的成長與基礎(chǔ)不一樣,結(jié)合自己的實際情況,在執(zhí)行。還是重復(fù)一下,前端的核心是js。css不難,但需要來積累。對前端我是這么看的:
css就像一瓶酒,得品。
html,css總共就那些標(biāo)簽跟選擇器屬性什么的,但是要寫一個有擴(kuò)展性,健壯性或維護(hù)性的頁面不容易?,F(xiàn)在寫頁面基本條件反射,不是如何快速的完成,而是思考如果有界面需求修改,怎么在修改代碼最少的情況下快速完成需求任務(wù)。這是對前端耐力,體力,智力的三重考驗。
js就像一把劍,得磨。
js剛開始只是為了較驗,隨便技術(shù)社會的發(fā)展,承擔(dān)的角色越來越重,剛開始玩玩jQuery感覺已經(jīng)會js了,其實只是冰山一角。隨著對js的了解越來越多,他即變態(tài)又可愛,即好玩又難控,即有很多兼容問題,但解決兼容是我們基本生存之道。從ajax到j(luò)smvc一路走一路看,高載潮一浪高過一浪
人生就是一場夢,得作。
技術(shù)只是生活的一部分,曾經(jīng)雄心斗志,如今低頭寫碼。改變能改變的,接受不能改變的。人生有限,兄爭朝夕啊。人生學(xué)習(xí)的態(tài)度是:不急不躁,不快不慢。持之以恒,相信自己。不求能改變世界,但求能改變自己的生活。不求健步如飛,但求一步一腳印。感謝磨難,他使我們內(nèi)心更為堅強(qiáng)。感謝挫折,他使我們不斷的成長,感謝bug,他使我們的思維更加深邃。感謝前端,他使我們更加的相信,撐起一片天空需要十八般武藝。
當(dāng)然可以。
只要自己努力,用心學(xué)習(xí),肯定能學(xué)好。JavaScript是腳本語言,主要用來編寫動態(tài)網(wǎng)頁。我建議你先從基本的HTML和CSS學(xué)起,學(xué)學(xué)靜態(tài)頁面布局。然后在網(wǎng)上找一些javascript入門級的視頻教程,按照教程一步步由淺入深按部就班的學(xué)習(xí)就OK。
編程一方面靠的是邏輯思維,另一方面也是一個孰能生巧的過程,只要多敲幾遍代碼,將基礎(chǔ)知識融會貫通,肯定能夠?qū)W好的。
自學(xué)要耐得住寂寞。最大的障礙是沒有學(xué)習(xí)氛圍,如果有條件的話,我還是建議你報個培訓(xùn)班。
開發(fā)環(huán)境越簡單越好,一定不要在這個環(huán)節(jié)浪費(fèi)時間。
首先說編輯器的選擇,sublime text、vs code、atom、webstorm,還有HBuilder。新手入門的時候總想找一個最好的編輯器,其實這編輯器就和游戲里面選英雄一樣,沒有最厲害的,只有最適合你的,如果還是拿不定注意,就選vs code吧,我感覺這個對新手挺友好的。
瀏覽器就用chrome,然后就可以開始擼代碼了。
關(guān)于JavaScript版本,我建議還是從ES5開始學(xué),有一定基礎(chǔ)之后再來看ES2015+的新特性。
基本語法
學(xué)編程語言和學(xué)自然語言有很多相似的地方,我們得從最基本的單詞和語法開始學(xué)。
變量:如何聲明變量,如何給變量賦值。
數(shù)據(jù)類型:什么是數(shù)據(jù)類型,數(shù)字與字符串有什么區(qū)別。
運(yùn)算符與表達(dá)式:常用的運(yùn)算符有哪些?“=”、“==”與“===”的區(qū)別等等。
分支語句:if、switch
循環(huán)語句:for、while
函數(shù):什么是函數(shù),什么是參數(shù),什么是返回值。
這些基本語法一定要非常熟悉,要不然后續(xù)的學(xué)習(xí)會舉步維艱。
對象
對象是一個非常重要的概念,一定要靈活掌握:
對象:屬性的無序集合,當(dāng)屬性值為函數(shù)的時候,我們叫這個函數(shù)為對象的方法。
數(shù)組:元素的有序集合。了解數(shù)組的常用方法
日期對象:獲取年月日時分秒
數(shù)學(xué)對象:獲取隨機(jī)數(shù)
了解其他對象:正則表達(dá)式、包裝對象,其實函數(shù)也是對象,不過這些簡單了解一下就行。
每個對象都有很多方法,這些方法知道在哪里查就行了,千萬不要去背,就像我們學(xué)英語,必要的單詞要背,但是大部分單詞知道用詞典查就行了。
DOM
DOM的樹狀結(jié)構(gòu)
節(jié)點:元素節(jié)點、文本節(jié)點、屬性節(jié)點
節(jié)點關(guān)系:同級、父子級等等
獲取節(jié)點:querySelector、querySelectorAll等等
節(jié)點操作:增刪改查
事件綁定:事件流和事件委托應(yīng)該了解一下
DOM提供的方法也很多,仍然不要過多的投入精力,新手自學(xué)總是會被這些大量的方法困擾,我們要做的是對DOM有一個概括性的了解,至于那些雜亂的接口,后續(xù)我們完全可以用jQuery或框架代替。
(如果對DOM感興趣,可以在技能掌握得稍微全面一些之后,再回來深入學(xué)習(xí)也是可以的,但是前期投入大量時間,確實會影響學(xué)習(xí)效率)
jQuery
jQuery是必須要會的,但是jQuery上手確實很簡單,用兩天時間了解一下jQuery的用法,然后就可以利用jQuery實現(xiàn)各種頁面效果了,前期肯定會磕磕絆絆,但是jQuery的資料有很多,一邊學(xué)一邊做就行。jQuery熟練了之后,就可以開始著手學(xué)習(xí)JavaScript進(jìn)階一點的內(nèi)容了:
原始類型與引用類型的區(qū)別
各種類型轉(zhuǎn)換和類型檢測
閉包:函數(shù)套函數(shù),怎么套自己都不蒙就行了。
原型:構(gòu)造函數(shù)、原型屬性、基于原型的繼承是怎么實現(xiàn)的。
this:可以開個坑好好研究研究
了解node
node現(xiàn)在可以說是前端必學(xué)的了,但是不是學(xué)用node做后臺,而是用node生態(tài)下的各種工具,順便借node了解一下后臺。
使用node開一個靜態(tài)服務(wù)器
使用npm下載第三方模塊
webpack
babel
最好能用express寫一個簡單的后臺程序(一個server.js就夠了),處理一些請求,這樣我們學(xué)習(xí)ajax的時候就可以自己寫后臺接口了,當(dāng)然這需要有http協(xié)議的基礎(chǔ)知識。
ES2+新特性
變量和常量:為什么要拋棄var?
結(jié)構(gòu)賦值
箭頭函數(shù)
模塊化
class
編譯
像promise,async/await函數(shù)等等這些,看自己能力了,有興趣看看,不看也不影響后面學(xué)習(xí),但是,就算現(xiàn)在不學(xué),這個后續(xù)也是要補(bǔ)的。
框架
react、vue選一,零基礎(chǔ)的初學(xué)者強(qiáng)烈推薦vue,如果技術(shù)型前端,推薦react。
0基礎(chǔ)學(xué)習(xí)Javascript的基礎(chǔ)知識一個月可以達(dá)到六成左右的水準(zhǔn),但是完整的學(xué)習(xí)Javascript基礎(chǔ)知識需 2-3 個月,如果想要深入學(xué)習(xí)則需要花費(fèi)更長的時間。如果你只是學(xué)會理論知識,而不懂得如何運(yùn)用的話,那么學(xué)習(xí)就是無用功。千鋒教育就有線上免費(fèi)Javascript線上公開課。 在學(xué)習(xí)Javascript時最好是邊學(xué)變練,也就是寫代碼。當(dāng)你學(xué)習(xí)完一個知識點的時候,要學(xué)會將它轉(zhuǎn)化。編程語言的學(xué)習(xí)最重要的就是能用它來開發(fā)系統(tǒng)。Javascript可以用來實現(xiàn)web 頁面動態(tài)響應(yīng)、響應(yīng)瀏覽器事件、讀寫HTML 元素、數(shù)據(jù)提交和驗證、檢測瀏覽器信息、控制 cookies,包括創(chuàng)建和修改等功能。如果想了解Javascript更多相關(guān)知識,建議到千鋒教育了解一下。千鋒教育目前在18個城市擁有22個校區(qū),年培養(yǎng)優(yōu)質(zhì)人才20000余人,與國內(nèi)20000余家企業(yè)建立人才輸送合作關(guān)系,院校合作超600所。
我嘗試著來回答這個問題,因為以前自己也有這方面的經(jīng)歷和困惑。
由于自己是CSS出身,一直以來只對CSS方面的話題感興趣,而且也一直沒有停過對CSS的探究。而對于JavaScript來說,早在很多年前都想學(xué),但一直沒有動力或者說沒有興趣。
興趣才是學(xué)習(xí)的一種最佳動力
記得在2013年開始我就常抱著JavaScript高級程序設(shè)計這本紅皮書,可是每次抱起來就沒多久被放下,重心又回到了CSS上。主要原因有兩點:
沒有壓迫感:從事的工作主要是以CSS為主,對于JavaScript幾乎沒有觸達(dá),這也應(yīng)了那么一句,沒有壓力就沒有動力
沒有興趣:對JavaScript只是想學(xué),而且知道學(xué)了對自己的好處,但始終沒有提起興趣,所以就沒有動力去堅持學(xué)習(xí)
后來隨著技術(shù)的革新,時代的變更,發(fā)現(xiàn)不懂JavaScript對自己的發(fā)展和學(xué)習(xí)都有很大的限制。比如說,我學(xué)習(xí)CSS的時候,需要寫一些測試案例,如果不具備JavaScript的能力,寫測試案例非常的費(fèi)用,如果你寫教程的話,對讀者也沒有一個更形象的展示。
再加上,進(jìn)入了一個新團(tuán)隊,業(yè)務(wù)上基本離不開JavaScript,特別是Vue,React這樣的框架出來之后,如果不懂JavaScript,那么更是舉步維艱,這也倒逼自己開始去學(xué)習(xí)JavaScript。
怎么學(xué)習(xí)JavaScript呢?對于我而言,只看書或只看教程,甚至看視頻是不夠的,還是無法提起我對JavaScript的興趣(雖然有工作壓力,業(yè)務(wù)壓力,學(xué)習(xí)壓力,環(huán)境壓力等在追著我向前)。既然知道這個原因所在,那么就需要想辦法去解決這個問題。而解決這個問題卻又不是刻意去解決的,也是在一次無形中解決的。
前幾天,工作內(nèi)容主要是圍繞著動效轉(zhuǎn),那么動效除了CSS是實現(xiàn)方式之外還有很多其他的方式,比如有很多優(yōu)秀的JavaScript庫,不懂JavaScript就無法去了解這些,更無法助力自己。另外就是Canvas,為了動效實現(xiàn)更具多方面的技巧,開始在學(xué)習(xí)Canvas,就在學(xué)習(xí)Canvas的過程中,讓我感覺到原來JavaScript也是這么的有意思。當(dāng)然,在學(xué)習(xí)Canvas的時候,也只是學(xué)習(xí)一些基礎(chǔ)的API,但這對我來說已經(jīng)是很大的變化了,因為從這些基礎(chǔ)的API能力上,能讓我寫一些簡單的效果出來,最為重要的是讓我對JavaScript有了興趣。
經(jīng)過一段時間Canvas的學(xué)習(xí)之后,發(fā)現(xiàn)不具備JavaScript的基礎(chǔ)是不夠的。從那開始,我注重JavaScript的基礎(chǔ)學(xué)習(xí),從DOM的操作開始,簡單點說,怎么對DOM進(jìn)行增、刪、改、查等操作。然后在操作DOM的時候會涉及到事處處理,那又開始會去學(xué)一些JavaScript中有關(guān)于事件方面的知識。
就是這樣,在學(xué)習(xí)一個新的東西的時候,總是會涉及到另外一部分未知的點。如果想打通這些點,就需要去學(xué)未知的點。也就是這樣一環(huán)道一環(huán),我一直在堅持學(xué)習(xí)一些JavaScript的基礎(chǔ)知識。
隨著React和Vue的出現(xiàn),自己工作中會用到相關(guān)的知識,那么在工作中總是會碰到一些問題,那么這些問題也是倒逼我去學(xué)JavaScript領(lǐng)域中未知的知識點。比如,函數(shù),繼承,設(shè)計模式等。雖然這些對我來說掌握的不多,不深,但也對自己而言也是一個較好的開始。我在想,只要堅持,總是會有收獲的。
隨著代碼寫得多了,就會想去了解其中的概念和原理,這個時候再重新抱起書本,獲取自己需要的知識點,感興還是蠻有意思的。
希望我的回答對你有幫助