前端和后端是計算機(jī)行業(yè)最常用的兩個術(shù)語;在某種程度上,它們成了流行語。它們決定了你作為軟件開發(fā)人員的工作類型、你使用的技術(shù)以及你得到的報酬。
那么,讓我們來談?wù)勥@兩個術(shù)語之間的區(qū)別,它們?yōu)槭裁词紫却嬖?,以及你在軟件開發(fā)職業(yè)生涯中可以采取的不同路徑。
站點(diǎn)呈現(xiàn)
用外行的話說,站點(diǎn)呈現(xiàn)意味著生成或呈現(xiàn)HTML輸出。HTML是web開發(fā)人員用來創(chuàng)建網(wǎng)頁的標(biāo)記語言。據(jù)說站點(diǎn)呈現(xiàn)可以在服務(wù)器端或客戶端級別進(jìn)行,那么這意味著什么呢?值得注意的是,前端和客戶端是同義詞,后端和服務(wù)器端也是如此。
客戶端呈現(xiàn)(前端)
在更現(xiàn)代的時代,出現(xiàn)了一種新的站點(diǎn)渲染形式,稱為客戶端渲染或前端開發(fā)。
通過客戶端呈現(xiàn),內(nèi)容的呈現(xiàn)在你的計算機(jī)中進(jìn)行,而不是使用事實(shí)上的web語言JavaScript在遠(yuǎn)程web服務(wù)器中進(jìn)行。實(shí)際上,這意味著服務(wù)器只需為原始web應(yīng)用程序提供服務(wù),瀏覽器將負(fù)責(zé)以最終形式HTML呈現(xiàn)此應(yīng)用程序。它還意味著創(chuàng)建網(wǎng)頁所涉及的一些邏輯,特別是負(fù)責(zé)處理如何在屏幕上向用戶呈現(xiàn)事物的邏輯(稱為呈現(xiàn)邏輯),在客戶端進(jìn)行處理。
隨著Angular、React和Vue等JavaScript庫的出現(xiàn),客戶端呈現(xiàn)變得越來越流行。
服務(wù)器端呈現(xiàn)(后端)
直到很久以前,服務(wù)器端渲染或后端web開發(fā)才成為創(chuàng)建網(wǎng)站和web應(yīng)用程序的實(shí)際方式。你訪問頁面,發(fā)送內(nèi)容請求,服務(wù)器處理該請求并創(chuàng)建一個響應(yīng),該響應(yīng)將發(fā)送回瀏覽器。
當(dāng)站點(diǎn)呈現(xiàn)服務(wù)器端時,創(chuàng)建web瀏覽器可以理解的HTML頁面所涉及的所有過程都在承載該網(wǎng)站或web應(yīng)用程序的遠(yuǎn)程服務(wù)器上處理。這包括查詢數(shù)據(jù)庫中的信息和處理web應(yīng)用程序所需的任何邏輯。
遠(yuǎn)程服務(wù)器工作繁忙時,你的web瀏覽器處于空閑狀態(tài),等待服務(wù)器完成處理請求和發(fā)送響應(yīng)。當(dāng)收到響應(yīng)時,web瀏覽器將對其進(jìn)行解釋并在屏幕上顯示內(nèi)容。
同構(gòu)呈現(xiàn)
也稱為通用呈現(xiàn),是現(xiàn)代web開發(fā)中使用的一種新技術(shù)。同構(gòu)呈現(xiàn)背后的思想是,在第一次加載頁面時在服務(wù)器端呈現(xiàn)使用JavaScript框架(如Angular、React或View)開發(fā)的web應(yīng)用程序,之后在客戶端呈現(xiàn)。更為復(fù)雜的是,還有另一種形式的呈現(xiàn)稱為預(yù)呈現(xiàn),它在編譯時呈現(xiàn)內(nèi)容。
在何處呈現(xiàn)站點(diǎn)通常取決于應(yīng)用程序的類型和應(yīng)用程序統(tǒng)計信息,并且會因團(tuán)隊(duì)和企業(yè)而異。
什么是前端開發(fā)?
現(xiàn)在我們了解了不同類型的站點(diǎn)呈現(xiàn)方法,更容易理解前端開發(fā)是創(chuàng)建在客戶端呈現(xiàn)的站點(diǎn)和web應(yīng)用程序的藝術(shù)。
用于前端開發(fā)的技術(shù)
雖然有許多不同類型的技術(shù)和堆棧,但大多數(shù)前端web開發(fā)人員使用HTML、CSS和JavaScript,它們是web事實(shí)上的構(gòu)建塊,以及客戶端框架,如Angular、React、Stencil和Vue。不過,并非所有事情都發(fā)生在前端。客戶端呈現(xiàn)的應(yīng)用程序仍然依賴于在后端遠(yuǎn)程服務(wù)器或云上運(yùn)行的服務(wù)和API。
什么是前端工作?
網(wǎng)頁設(shè)計師:你猜對了,網(wǎng)頁設(shè)計師設(shè)計網(wǎng)站。不過,網(wǎng)頁設(shè)計師的頭銜相當(dāng)寬泛。網(wǎng)頁設(shè)計師可能只是在Photoshop或Fireworks之類的程序中設(shè)計網(wǎng)站的人,而且永遠(yuǎn)不會觸碰代碼。但在另一個地方,網(wǎng)頁設(shè)計師可以在Photoshop中完成所有的設(shè)計組合,然后負(fù)責(zé)創(chuàng)建所有的HTML和CSS(有時甚至是JavaScript)來配合它。
用戶界面(UI)設(shè)計器:這基本上是一個可視化設(shè)計器,通常側(cè)重于設(shè)計。他們通常不參與設(shè)計的實(shí)現(xiàn),但他們可能知道輕松的HTML和CSS,這樣他們就可以更有效地與前端開發(fā)人員交流他們的想法。
用戶體驗(yàn)(UX)設(shè)計師:UX設(shè)計師在前端工作,研究人們?nèi)绾问褂镁W(wǎng)站。然后,他們通過大量測試進(jìn)行更改。
前端開發(fā)人員:也稱為前端設(shè)計師,他們可以創(chuàng)建一個沒有任何后端開發(fā)的站點(diǎn)。他們在沒有web開發(fā)人員或使用后端的情況下創(chuàng)建的站點(diǎn)是靜態(tài)站點(diǎn)。靜態(tài)站點(diǎn)類似于餐廳或發(fā)廊的站點(diǎn)。它不需要在數(shù)據(jù)庫中存儲任何信息。頁面幾乎總是保持不變,除非是時候重新設(shè)計了。前端開發(fā)人員可能需要掌握測試,并且精通HTML、CSS和JavaScript。此人可能有也可能沒有在設(shè)計程序中創(chuàng)建設(shè)計的經(jīng)驗(yàn)。這個標(biāo)題的另一個版本是前端工程師。使用特定前端語言(如JavaScript developer)的人也被視為前端開發(fā)人員。
什么是后端開發(fā)?
前端開發(fā)是讓站點(diǎn)和web應(yīng)用程序在客戶端呈現(xiàn),而后端開發(fā)則是讓這些應(yīng)用程序在服務(wù)器端呈現(xiàn)。但它比這要復(fù)雜一點(diǎn)。雖然前面的說法是正確的,但后端開發(fā)人員也創(chuàng)建處理業(yè)務(wù)邏輯和訪問其他資源(如數(shù)據(jù)庫、文件服務(wù)器、云服務(wù)等)的服務(wù)。這些服務(wù)是任何應(yīng)用程序的主干,不僅可以由服務(wù)器端渲染應(yīng)用程序訪問和使用,還可以從客戶端渲染應(yīng)用程序訪問和使用。
用于后端開發(fā)的技術(shù)
當(dāng)后端開發(fā)人員創(chuàng)建在服務(wù)器端呈現(xiàn)的應(yīng)用程序時,他們使用與前端開發(fā)人員相同的構(gòu)建塊:HTML、CSS和JavaScript。
后端開發(fā)人員還使用軟件堆棧,包括操作系統(tǒng)、web服務(wù)器、框架、語言、編程API等。這些堆棧中的框架、語言和編程API用于呈現(xiàn)服務(wù)器端站點(diǎn)和web應(yīng)用程序,并創(chuàng)建其他應(yīng)用程序可以使用的服務(wù)。
什么是全棧開發(fā)?
作為一名完整的堆棧開發(fā)人員,您可以同時完成前后端兩項(xiàng)工作。全棧開發(fā)人員可以創(chuàng)建同時在客戶端(前端)和服務(wù)器端(后端)呈現(xiàn)的站點(diǎn)和web應(yīng)用程序。
他們還創(chuàng)建服務(wù)、組件和API來封裝業(yè)務(wù)邏輯、解決特定的業(yè)務(wù)問題和訪問數(shù)據(jù)庫、文件服務(wù)器、云服務(wù)等基礎(chǔ)設(shè)施。他們的工作與完整的堆棧,這是最好的兩個世界。