最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

web全棧該怎么自學(xué)

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 15:21:52
文檔

web全棧該怎么自學(xué)

web全棧該怎么自學(xué):互聯(lián)網(wǎng)行業(yè)現(xiàn)今一直都很火熱,相信未來也會(huì)是一直保持火熱的狀態(tài)。所以有很多朋友都開啟了學(xué)習(xí)互聯(lián)網(wǎng)學(xué)習(xí)的計(jì)劃,有人選擇培訓(xùn),有人選擇自學(xué)。但是對(duì)于學(xué)習(xí)互聯(lián)網(wǎng)技術(shù),應(yīng)該有很多朋友都會(huì)感到迷茫吧。前幾天,就有朋友問想自學(xué)web全棧應(yīng)該怎么去做。下面我
推薦度:
導(dǎo)讀web全棧該怎么自學(xué):互聯(lián)網(wǎng)行業(yè)現(xiàn)今一直都很火熱,相信未來也會(huì)是一直保持火熱的狀態(tài)。所以有很多朋友都開啟了學(xué)習(xí)互聯(lián)網(wǎng)學(xué)習(xí)的計(jì)劃,有人選擇培訓(xùn),有人選擇自學(xué)。但是對(duì)于學(xué)習(xí)互聯(lián)網(wǎng)技術(shù),應(yīng)該有很多朋友都會(huì)感到迷茫吧。前幾天,就有朋友問想自學(xué)web全棧應(yīng)該怎么去做。下面我
互聯(lián)網(wǎng)行業(yè)現(xiàn)今一直都很火熱,相信未來也會(huì)是一直保持火熱的狀態(tài)。所以有很多朋友都開啟了學(xué)習(xí)互聯(lián)網(wǎng)學(xué)習(xí)的計(jì)劃,有人選擇培訓(xùn),有人選擇自學(xué)。但是對(duì)于學(xué)習(xí)互聯(lián)網(wǎng)技術(shù),應(yīng)該有很多朋友都會(huì)感到迷茫吧。前幾天,就有朋友問想自學(xué)web全棧應(yīng)該怎么去做。下面我將和大家一起談?wù)勅绾巫詫W(xué)web全棧。

首先,你要了解什么是web全棧,以及知道web全棧需要學(xué)習(xí)哪些知識(shí)。

其次,你要知道自學(xué)web全棧,不是一件簡單的事情,需要你有足夠的毅力去堅(jiān)持,也需要你有高效學(xué)習(xí)的能力,才能在盡量短的時(shí)間內(nèi)學(xué)好它。

一個(gè)Web開發(fā)過程有三層架構(gòu):

表示層:表示層也被稱為網(wǎng)站的前端部分。它處理網(wǎng)站的用戶界面相關(guān)問題。

業(yè)務(wù)邏輯層:業(yè)務(wù)邏輯層也被稱為網(wǎng)站的后端層,負(fù)責(zé)數(shù)據(jù)驗(yàn)證和動(dòng)態(tài)處理。

數(shù)據(jù)庫層:最后是數(shù)據(jù)訪問層,利用API為網(wǎng)站提供數(shù)據(jù)。

以上三層共同稱為全棧web開發(fā)。

作為web全棧工程師你需要知道以下知識(shí):

1、服務(wù)管理/運(yùn)維

一個(gè)開發(fā)者必須了解基礎(chǔ)的服務(wù)器管理知識(shí)。包括當(dāng)不限于以下知識(shí):

通過終端或其他沒有用戶界面的環(huán)境來遠(yuǎn)程連接服務(wù)器

會(huì)寫基本的shell腳本

服務(wù)器上的用戶和群組管理

管理像Apache和Nginx這樣的服務(wù)器程序來提供應(yīng)用

防火墻管理和權(quán)限管理

安裝和更新軟件

除了這些基礎(chǔ)技能,開發(fā)者必須懂得怎樣去創(chuàng)建一個(gè)好的、健康的、分離的開發(fā)環(huán)境,在 Docker 或者像 Vagrant 這樣的虛擬機(jī)環(huán)境中。如果上面所有的技術(shù)你都不熟悉,那我必須給你推薦一本超棒的書,點(diǎn)這里購買。

開發(fā)者必須對(duì)版本控制系統(tǒng)非常熟練,為了讓開發(fā)有靠譜的生產(chǎn)備份和可分享、可協(xié)同的代碼庫,這些代碼庫能夠根據(jù)時(shí)間來跟蹤代碼變化。現(xiàn)在已經(jīng)沒有開發(fā)者的工作流是完全離開版本控制的了。我們有一個(gè)非常棒的關(guān)于版本控制的視頻教程,點(diǎn)這里購買。

2、云

和實(shí)際管理或者虛擬服務(wù)器不同,一個(gè)開發(fā)者也許要知道云主機(jī)平臺(tái),比如Heroku, Google Cloud, Azure, AWS等等。

有一點(diǎn)必須說明的是,平臺(tái)和工具更多的是為了炒作而不是其實(shí)用性。盡管有很多平臺(tái)和工具的實(shí)用性并不如宣傳的那么好,但是了解這些大家都在談?wù)摰姆?wù),從長遠(yuǎn)來看會(huì)很有用――客戶可能會(huì)隨時(shí)要求更換服務(wù)提供商。幸運(yùn)的是,我們擁有這些云主機(jī)部署權(quán)威指南。

3、后端

在后端,除了要懂選擇什么語言以外,比如 PHP 和眾多的框架 and CMSes,一個(gè)全棧開發(fā)者必須熟悉:

Web服務(wù)器,比如Nginx和Apache,和運(yùn)維緊密相關(guān)

不幸的是,NodeJS 已經(jīng)可以將 JS、CSS 和其他資源文件編譯成靜態(tài)可以方便緩存的文件了。幸運(yùn)的是,也有辦法避免學(xué)習(xí) NodeJS,用PHP也是可以的

像Composer這樣的PHP(http://www.ujiuye.com/zt/php/)包管理工具在現(xiàn)代化的開發(fā)環(huán)境中已經(jīng)離不開了

好的API 設(shè)計(jì),自從大部分新型網(wǎng)頁都基于 API 而且僅僅為前端服務(wù)(下面會(huì)詳細(xì)描述)

ElasticSearch (introduction here)這樣的搜索引擎對(duì)于網(wǎng)站性能的提高是非常重要的

cronjobs 和后端的工作,使用Gearman 或者 Crunz 這類的庫

了解緩存,Varnish, Redis 等牛B的工具可以分片存儲(chǔ)數(shù)據(jù),這樣可以將一個(gè)項(xiàng)目部署的多個(gè)主機(jī)上

4、數(shù)據(jù)庫

數(shù)據(jù)庫是一個(gè)單獨(dú)的部分,因?yàn)槌撕芎玫卣莆瘴覀兓旧喜粫?huì)有結(jié)構(gòu)變化的關(guān)系數(shù)據(jù)庫(MySQL或者PostgreSQL)的數(shù)據(jù)模式之外,一個(gè)全棧工程師應(yīng)該對(duì)非關(guān)系型數(shù)據(jù)庫有所了解,如MongoDB, Redis,或Cassandra ,更不用說像Neo4j這樣的圖形數(shù)據(jù)庫了。

不幸的是,這些都是服務(wù)器上的東西,都在全棧工程師的控制下。也有幾個(gè)類似 Mong 的遠(yuǎn)程解決方案,像RestDB或者Google-owned Firebase等。

5、前端

想知道一個(gè)正常的前端知識(shí)圖譜是怎么樣的,可以在JavaScript 版塊看這篇絕世好文。但是作為一個(gè)全棧工程師,你需要了解

NodeJS and NPM

Yarn

預(yù)處理器和編譯器(如Babel),用來編譯 Typescript, ES6, LESS, SCSS, SaSS

構(gòu)建工具,如 Grunt 和 Gulp

框架,如 VueJS、React、Angular

模塊打包工具,如 Webpack、Browserify、Rollup

6、設(shè)計(jì)

在設(shè)計(jì)方面,全棧開發(fā)者需要了解怎樣在一個(gè)產(chǎn)品變成真正可用的 HTML 、CSS 代碼之前,畫一個(gè)原型圖。然后就可以去用 JS 寫交互、后端也可以用假數(shù)據(jù)來模擬生產(chǎn)環(huán)境。只有這個(gè)關(guān)鍵的原型圖完成,用戶體驗(yàn)設(shè)計(jì)和接口設(shè)計(jì)就緒,真正的開發(fā)才能開始。這本身就是一項(xiàng)艱巨的任務(wù),需要一套特殊的工具:

Photoshop和Illustrator 或者一些開源的工具比如Gimp/Inkscape。訪問Design channel來了解更多這樣的工具。

一個(gè)牛的、快速的編輯器,比如Atom或Sublime Text(這兒有十種好用的sublime插件)

像Subtlepatterns的背景選擇器和顏色選擇器能夠搭配一些顏色

CSS的柵格系統(tǒng)

上面所說的前端所需要了解的所有知識(shí)和 JS 數(shù)據(jù)模擬

將原型圖發(fā)表到網(wǎng)上供大家瀏覽并給于反饋,Ngrok就非常好用

7、日志系統(tǒng)

為了高效監(jiān)控應(yīng)用的健康度,全棧開發(fā)者必須能夠追蹤錯(cuò)誤,找到錯(cuò)誤日志然后從中提取出有用的信息。全棧開發(fā)者也需要從日志中預(yù)測一些趨勢,比如 CPU 或者 I/O 占用率的上漲,以防應(yīng)用不知道什么時(shí)候就掛了。這部分和運(yùn)維也有一些關(guān)系,但是需要一些特別的技能:

推薦一篇非常棒的ELK stack的文章,這會(huì)幫助你了解做日志系統(tǒng)所需要的知識(shí)。里面包括了查找日志的ElasticSearch ,收集日志的Logstash,把日志用非常棒的圖表展現(xiàn)出來的的Kibana,甚至還有提供解決方案的Logz.io。

8、移動(dòng)端

最后,我們?cè)撜f說移動(dòng)端了。隨著iOS和安卓上的的webview變得越來越高效,還有 PWA(漸進(jìn)式web應(yīng)用)的到來,native 應(yīng)用正在變得黯淡,因?yàn)樗麄冮_發(fā)起來實(shí)在是太復(fù)雜了。所以一個(gè)全棧工程師必須了解 PWA 或者 React Native,或者像NativeScript, Tabris, Cordova, Phonegap或者其他webview來讓客戶端應(yīng)用調(diào)用 API跑起來。

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

web全棧該怎么自學(xué)

web全棧該怎么自學(xué):互聯(lián)網(wǎng)行業(yè)現(xiàn)今一直都很火熱,相信未來也會(huì)是一直保持火熱的狀態(tài)。所以有很多朋友都開啟了學(xué)習(xí)互聯(lián)網(wǎng)學(xué)習(xí)的計(jì)劃,有人選擇培訓(xùn),有人選擇自學(xué)。但是對(duì)于學(xué)習(xí)互聯(lián)網(wǎng)技術(shù),應(yīng)該有很多朋友都會(huì)感到迷茫吧。前幾天,就有朋友問想自學(xué)web全棧應(yīng)該怎么去做。下面我
推薦度:
標(biāo)簽: 如何 學(xué)習(xí) 怎么
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top