當(dāng)然,在搜索的過程中,你會碰到的崗位名稱可遠(yuǎn)不止這些。但可以確定的一點(diǎn)是,這些對 Web 開發(fā)崗位來說,是最常見不過的了。
一篇讀懂 | 前端、后端、全棧都是干啥的?干哪個錢多?
那么,今天就讓我們好好聊聊這幾個崗位,也希望能為將來要進(jìn)入這個領(lǐng)域的新手指引一下方向。
所以,為啥要有這么多不同的崗位名稱呢?
這些崗位名稱,每一種都代表了應(yīng)聘者/員工需要掌握的一大類特定的技術(shù)體系。
如今,網(wǎng)絡(luò)技術(shù)的發(fā)展不斷加快,復(fù)雜度也不斷提高。隨之而來的是,在某些開發(fā)流程中,程序員的崗位內(nèi)容也變得更具專門性。換句話說,對于 Web 應(yīng)用的每個不同的屬性,對某些特定的編程語言、框架或是技術(shù)上的專門知識,我們都有一個專門的職位,用于描述在工作中使用這一系列技術(shù)的開發(fā)者。
對剛?cè)腴T新手,或是正在嘗試在這一領(lǐng)域求職的人來說,你需要理解“前端”“后端”和“全棧”之間的區(qū)別,以便更好地充實(shí)自己的技術(shù)儲備。每一種崗位,你都必須具備一套不同的技術(shù)儲備。然而,要在它們之間畫出一條嚴(yán)格的界限,并不是件容易的事。每一個崗位都帶有一系列 必須掌握的附加技能。是的,如果你希望能成為一名更好的開發(fā)者,你就需要對這三種崗位的特性有比較好的理解。
好吧,我啰里啰唆地講了這么多,現(xiàn)在就讓我們詳細(xì)聊一聊“前端”“后端”“全?!惫こ處煻家鲂┦裁?,以及你需要哪些技能才能勝任這些工作。
前端開發(fā)者的工作,就是構(gòu)建一個網(wǎng)頁 APP 中你能直接看到并與之交互的部分。想象一下,對一個網(wǎng)站來說,它可能有設(shè)計(jì)師設(shè)計(jì)好了 Logo,有攝影師提供的精彩照片,還有作者們提供的文字與內(nèi)容等各種素材。那么,簡單地說,前端開發(fā)者就是把這些素材都整合在一起,形成一個我們可以瀏覽的網(wǎng)站頁面。
為此,前端開發(fā)者需要深入掌握三種語言: HTML、CSS 以及 Javascript。
HTML——超文本標(biāo)記語言——是網(wǎng)頁的骨架,是每個網(wǎng)站必備的基礎(chǔ)。簡單地說,HTML 文檔中包含了各種成對的標(biāo)簽,網(wǎng)頁上的各種元素通過這個標(biāo)簽組合成了一個整體。
CSS——層疊樣式表——是讓HTML結(jié)果變得更加好看的樣式規(guī)則。這讓網(wǎng)頁能夠擁有各種顏色、字體以及背景圖案。CSS 可以用與管理網(wǎng)頁上的各種元素,并控制這些元素在頁面上的位置與樣式。
最后是 Javascript,它是網(wǎng)頁動畫與交互的魔法之源,也是構(gòu)建一個 Web 應(yīng)用的核心部分。
如果你想要從事前端開發(fā),上面這些就是你必須掌握的基礎(chǔ)技能。但前端開發(fā)可遠(yuǎn)不止于此。有許多框架可以被用在這些語言上,比如 Bootstrap、Semantic-UI 以及 Foundation 等。它們能讓你的應(yīng)用更加美觀,也更易使用。此外,還有許多代碼庫,比如 jQuery、React 以及 Angular 等。在這些已經(jīng)包裝好的代碼庫的幫助下,你能方便而直接地引入許多有用的功能,省下許多重復(fù)造輪子的時間。此外,你可能還會碰到 Node.js,在這一跨平臺環(huán)境的加持下,你能用 Javascript 給前端和后端程序編寫代碼。最后,一些 Ajax 技術(shù)能讓網(wǎng)頁更加動態(tài)化,還能讓網(wǎng)頁更好地和后端的數(shù)據(jù)服務(wù)器協(xié)同工作。
使用這些技術(shù),前端開發(fā)者能連接起網(wǎng)站設(shè)計(jì)者和后端開發(fā)者之間的橋梁。他們能提供用戶體驗(yàn)方面的分析,構(gòu)建模型和線框,給設(shè)計(jì)團(tuán)隊(duì)提出建議。他們能給后端編寫的服務(wù)應(yīng)用賦予生命,提升格調(diào),營造美感。
前端開發(fā)關(guān)注的是用戶見到并交互的內(nèi)容,而這一切的幕后驅(qū)動力,則來自后端開發(fā)者的勞動。你訪問的這個網(wǎng)站之所以會存在,完全是因?yàn)楹蠖朔?wù)器將這些數(shù)據(jù)發(fā)送到了你的計(jì)算機(jī)或者移動設(shè)備上。不僅如此,被傳送的這些網(wǎng)頁、表單、用戶賬號,以及所有相關(guān)的個人信息等數(shù)據(jù),全部都是由后端團(tuán)隊(duì)進(jìn)行存儲和操作的。
后端開發(fā)者的工作就是保證服務(wù)器、應(yīng)用程序和數(shù)據(jù)庫之間的正常通信和協(xié)作。因此,他們使用的更多是服務(wù)器端的編程語言——PHP、Ruby、Python、Java 甚至 .Net,一邊構(gòu)建出足夠健壯的服務(wù)器程序,驅(qū)動網(wǎng)頁應(yīng)用的正常運(yùn)作。此外,他們需要使用諸如 MySQL、Oracle 以及 SQL Server 等數(shù)據(jù)庫,來保存、修改、更新以及刪除服務(wù)器上的數(shù)據(jù)。后端開發(fā)的工作還可能需要掌握一些特定的框架,比如 Zend、Symfony 以及 CakePHP,或許還需要一些 Linux 方面的知識。
如果你想找一個后端開發(fā)的工作,你會發(fā)現(xiàn)許多崗位往往都被冠以某一個基礎(chǔ)語言的名字,比如 **Ruby 程序員** 或者 **PHP 程序員**。編程語言是這一職位的關(guān)鍵要素,因?yàn)槟阍诤蠖碎_發(fā)時使用的這些應(yīng)用,往往也都是用同一門語言編寫的。
說到這里,你可能會想,“如果 Javascript 已經(jīng)能搞定動畫創(chuàng)建和交互邏輯,我真的會需要一門后端語言嗎?”。確實(shí),現(xiàn)在的 JS 已經(jīng)擺脫了許多以往存在的限制與不足,并且純 JS 已經(jīng)能完成幾乎無限的可能。然而,對于大型且復(fù)雜的后端應(yīng)用來說,為了保證性能,一個專業(yè)的后端編程語言還是非常有必要的。況且,學(xué)習(xí)多門編程語言,能讓你從不同的角度進(jìn)行思考,并針對某個特定的情況選擇最適合的解決方案。
后端開發(fā)者需要編寫出與業(yè)務(wù)策略相協(xié)調(diào)的代碼,將企業(yè)的需要翻譯成技術(shù)需求,并最終確定最高效的服務(wù)器與數(shù)據(jù)庫架構(gòu)。
全棧開發(fā)者,顧名思義,就是前端和后端的活兒都能干。這里的“?!敝傅氖蔷W(wǎng)頁應(yīng)用的各個層,也就是這樣的開發(fā)者具備了包括服務(wù)器程序、數(shù)據(jù)結(jié)構(gòu)與模型、用戶界面、用戶體驗(yàn)等多層次的技術(shù),掌握了業(yè)務(wù)中所需要的每一個階段的技術(shù)。沒錯,沒錯,“全?!币馕吨阋呀?jīng)完全了解整個開發(fā)流程中的每一個環(huán)節(jié)。
不過,和你想的不太一樣,全棧開發(fā)并不意味著整個項(xiàng)目都是你一個人來干。在大多數(shù)情況下,全棧開發(fā)者還是會將主要的精力花在前端或者后端之一的開發(fā)流程上。但和其他開發(fā)者不同的是,全棧開發(fā)者能在需要的時候跨越項(xiàng)目中的界限,比如能在改善用戶體驗(yàn)的同時,優(yōu)化數(shù)據(jù)庫的模型。
全棧開發(fā)者的一個常見情況是,他們通常會專用一種后端編程語言,比如 Ruby 全棧開發(fā)者,或者 Python 全站開發(fā)者等等。
事實(shí)上,技術(shù)的領(lǐng)域始終處于變化之中,正如你能看到各種新型的手機(jī)和電腦不斷出現(xiàn)一樣。對于技術(shù)崗位而言也是如此。最常用的語言、最熱門的框架隨著時間的推移也總會改變,甚至它們的版本和語法都會不一樣。要想變成一名多才多藝的開發(fā)者,前端和后端的各項(xiàng)技術(shù)都是至關(guān)重要的,能讓你更好地面對未來可能發(fā)生的改變。
但是,無論您選擇首先將精力放在哪種語言上,你都要清楚地理解這門語言的各種細(xì)節(jié)、可使用的框架和第三方庫等。這會使你在就業(yè)市場中獲得較為顯著的優(yōu)勢。在爭取某個項(xiàng)目職位的時候,那些掌握了足夠語言知識的人,那些熟悉框架和庫并讓代碼更加簡潔的人,以及那些更好地遵循應(yīng)用文檔的人,總是更容易脫穎而出。
就是這樣!讓我們一起努力吧!
聯(lián)系客服