什么是前后端分離?

在網(wǎng)站開(kāi)發(fā)過(guò)程中策泣,對(duì)于前后端的分界線似乎一直是眾說(shuō)紛紜衙傀。在網(wǎng)上搜索什么是前后端分離,更是說(shuō)什么的都有萨咕,天花亂墜统抬,描述不清。從一開(kāi)始完全沒(méi)有前后端的概念危队,到后來(lái)的糾纏不清聪建。

傳統(tǒng)的分離方法

在我的腦海中一提到前端和后端,基本上第一個(gè)出現(xiàn)的區(qū)別點(diǎn)就是:后端是跟數(shù)據(jù)庫(kù)跟服務(wù)器打交道的茫陆,前端是跟瀏覽器打交道的金麸。似乎沒(méi)有什么問(wèn)題,大家都這么認(rèn)為的簿盅。當(dāng)然這沒(méi)有什么錯(cuò)挥下,我們一直以來(lái)都認(rèn)為僅僅是以瀏覽器作分界揍魂,把這兩部分的代碼分離出來(lái)。但是前后端分離的初衷是為了分離前后端開(kāi)發(fā)人員的職責(zé)棚瘟,同時(shí)解決開(kāi)發(fā)模式的問(wèn)題现斋。但似乎他們的職責(zé)在以前甚至于現(xiàn)在都并不明確,雖然前端是跟瀏覽器打交道偎蘸,但是最終瀏覽器拿到的頁(yè)面是服務(wù)器通過(guò)模板生成的一個(gè)臨時(shí)靜態(tài)頁(yè)面而已庄蹋。所以,實(shí)際上后端也摻和進(jìn)來(lái)了禀苦,因?yàn)樗幚砟0迓稀.?dāng)然,一般傳統(tǒng)上的開(kāi)發(fā)協(xié)作模式有兩種:

一種是前端先寫(xiě)一個(gè)靜態(tài)頁(yè)面振乏,寫(xiě)好后蔗包,讓后端去套模板。靜態(tài)頁(yè)面可以本地開(kāi)發(fā)慧邮,也無(wú)需考慮業(yè)務(wù)邏輯只需要實(shí)現(xiàn)View即可调限。不足是還需要后端套模板,這些前端代碼后端需要瀏覽一遍误澳,以免出錯(cuò)耻矮。

另一種協(xié)作模式是,前端直接去寫(xiě)模板忆谓,這樣做的問(wèn)題在于裆装,前端編寫(xiě)過(guò)程中很依賴與后端環(huán)境,如果當(dāng)后端沒(méi)寫(xiě)完的情況下倡缠,前端幾乎沒(méi)法干活哨免。

顯然這兩種方式似乎都有很多問(wèn)題,但至少這還是目前為止大部分公司所采用的模式昙沦。他們從物理層來(lái)區(qū)分前后端的開(kāi)發(fā)琢唾,同時(shí)淡化了前端在邏輯上的色彩。由于前端所做的事情就是來(lái)實(shí)現(xiàn)一個(gè)頁(yè)面的靜態(tài)版本盾饮,所以采桃,大多數(shù)公司又給前端工程師們找了點(diǎn)活干。你去看現(xiàn)在公司在招聘的時(shí)候前端工程師的要求丘损,除了對(duì)頁(yè)面的基本制作技能外還有額外的設(shè)計(jì)職責(zé)普办。例如至少會(huì)一門后端編程語(yǔ)言NodeJs或者php或者Java。

到這里原本我們以為已經(jīng)將前后端分離開(kāi)來(lái)了徘钥,但是在模版這個(gè)尷尬的問(wèn)題上衔蹲,前后端的工程師們絕對(duì)吃過(guò)不少苦頭。目前直接在jsp或是php里面寫(xiě)html應(yīng)該不多了吏饿。前后端分離正在是正火踪危。那么怎么分離,誰(shuí)占的多點(diǎn)猪落,誰(shuí)占的少點(diǎn)贞远,根據(jù)各個(gè)公司的技術(shù)水平來(lái)。前端開(kāi)發(fā)工程師牛了笨忌,就想著前端的mvc,mvvm蓝仲,直出。后端牛了官疲,就想著袱结,你把這個(gè)原型給后端,其他不用管了途凫。

傳統(tǒng)的開(kāi)發(fā)方法

之前的php代碼寫(xiě)在html代碼里,不存在純粹的php文件和html文件,這里就是前后端不分離,大概意思就是php和html,你中我有,我中有你.

但是呢,后來(lái)開(kāi)發(fā)的時(shí)候遇到很多問(wèn)題,前端(html,css,js)工程師對(duì)php代碼可能讀不懂,php工程師也不對(duì)css那些內(nèi)容非常熟悉,所以后來(lái)人們想出一個(gè)辦法,把代碼分離!這樣就能讓每個(gè)人在各自的領(lǐng)域更好的發(fā)揮,這樣雖然消耗了一定的效率,但是對(duì)于開(kāi)發(fā)人員從某一角度來(lái)說(shuō)是友好的.

前后端分離并沒(méi)有網(wǎng)上說(shuō)的那么復(fù)雜垢夹。

1.首先要知道所有的程序都是一數(shù)據(jù)為基礎(chǔ)的,沒(méi)有數(shù)據(jù)的程序沒(méi)有實(shí)際意義维费,程序的本質(zhì)就是對(duì)程序的增刪改查果元。

2.前后端分離就是把數(shù)據(jù)操作和顯示分離出來(lái)。前端專注做數(shù)據(jù)顯示犀盟,通過(guò)文字而晒,圖片或者圖標(biāo)等方式讓數(shù)據(jù)形象直觀的顯示出來(lái)。后端專注做數(shù)據(jù)的操作阅畴。前端把數(shù)據(jù)發(fā)給后端倡怎,有后端對(duì)數(shù)據(jù)進(jìn)行修改。

3.后端一般用java贱枣,c#等語(yǔ)言监署,現(xiàn)在的node屬于JavaScript也能進(jìn)行后端操作,此處不意義裂解語(yǔ)言冯事。后端來(lái)進(jìn)行數(shù)據(jù)庫(kù)的鏈接焦匈,并對(duì)數(shù)據(jù)進(jìn)行操作。

4.后端提供接口給前端調(diào)用昵仅,來(lái)觸發(fā)后端對(duì)數(shù)據(jù)的操作缓熟。

基本原理就是這樣,可能語(yǔ)言上不準(zhǔn)確摔笤,思想是沒(méi)有問(wèn)題的够滑。

所以開(kāi)發(fā)網(wǎng)站的核心現(xiàn)在基本上就是:

html + css :頁(yè)面展示

javascript + ajax(這個(gè)算是瀏覽器的一部分轻姿,可以通過(guò) javascript 調(diào)用) : 頁(yè)面交互穿铆、邏輯處理

通常的開(kāi)發(fā)框架選擇:

簡(jiǎn)單網(wǎng)站: jquery + bootstrap

后臺(tái)管理系統(tǒng): angularjs + jquery + bootstrap + webpack

復(fù)雜的產(chǎn)品: react + redux + webpack

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市塞绿,隨后出現(xiàn)的幾起案子命辖,更是在濱河造成了極大的恐慌况毅,老刑警劉巖分蓖,帶你破解...
    沈念sama閱讀 223,207評(píng)論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異尔许,居然都是意外死亡么鹤,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評(píng)論 3 400
  • 文/潘曉璐 我一進(jìn)店門味廊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蒸甜,“玉大人,你說(shuō)我怎么就攤上這事余佛∧拢” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 170,031評(píng)論 0 366
  • 文/不壞的土叔 我叫張陵辉巡,是天一觀的道長(zhǎng)恨憎。 經(jīng)常有香客問(wèn)我,道長(zhǎng)郊楣,這世上最難降的妖魔是什么框咙? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,334評(píng)論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮痢甘,結(jié)果婚禮上喇嘱,老公的妹妹穿的比我還像新娘。我一直安慰自己塞栅,他們只是感情好者铜,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,322評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著放椰,像睡著了一般作烟。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上砾医,一...
    開(kāi)封第一講書(shū)人閱讀 52,895評(píng)論 1 314
  • 那天拿撩,我揣著相機(jī)與錄音,去河邊找鬼如蚜。 笑死压恒,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的错邦。 我是一名探鬼主播探赫,決...
    沈念sama閱讀 41,300評(píng)論 3 424
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼撬呢!你這毒婦竟也來(lái)了伦吠?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 40,264評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎毛仪,沒(méi)想到半個(gè)月后搁嗓,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,784評(píng)論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡箱靴,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,870評(píng)論 3 343
  • 正文 我和宋清朗相戀三年谱姓,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片刨晴。...
    茶點(diǎn)故事閱讀 40,989評(píng)論 1 354
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖路翻,靈堂內(nèi)的尸體忽然破棺而出狈癞,到底是詐尸還是另有隱情,我是刑警寧澤茂契,帶...
    沈念sama閱讀 36,649評(píng)論 5 351
  • 正文 年R本政府宣布蝶桶,位于F島的核電站,受9級(jí)特大地震影響掉冶,放射性物質(zhì)發(fā)生泄漏真竖。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,331評(píng)論 3 336
  • 文/蒙蒙 一厌小、第九天 我趴在偏房一處隱蔽的房頂上張望恢共。 院中可真熱鬧,春花似錦璧亚、人聲如沸讨韭。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,814評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)透硝。三九已至,卻和暖如春疯搅,著一層夾襖步出監(jiān)牢的瞬間濒生,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,940評(píng)論 1 275
  • 我被黑心中介騙來(lái)泰國(guó)打工幔欧, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留罪治,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,452評(píng)論 3 379
  • 正文 我出身青樓礁蔗,卻偏偏與公主長(zhǎng)得像规阀,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瘦麸,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,995評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 傳統(tǒng)的分離方法 在我的腦海中一提到前端和后端谁撼,基本上第一個(gè)出現(xiàn)的區(qū)別點(diǎn)就是:后端是跟數(shù)據(jù)庫(kù)跟服務(wù)器打交道的,前端是...
    L怪丫頭閱讀 2,221評(píng)論 0 2
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,352評(píng)論 25 707
  • 本文系轉(zhuǎn)載喊巍,原作者,普元箍鼓,敖顯奇 轉(zhuǎn)載本文需保留此處版權(quán)聲明:本文版權(quán)屬于EAII企業(yè)架構(gòu)創(chuàng)新研究院(微信號(hào):ea...
    普元云計(jì)算閱讀 4,978評(píng)論 8 96
  • 文字來(lái)源網(wǎng)絡(luò) 愛(ài)喝茶的人崭参,在人群中一眼就看得出,你信不信款咖? 長(zhǎng)期喝茶能給我們帶來(lái)了什么呢何暮?茶的飲用價(jià)值提升了我們的...
    ifeng峰回路轉(zhuǎn)閱讀 1,117評(píng)論 0 3
  • “找一個(gè)會(huì)幫你擦干頭發(fā),會(huì)低頭給你系鞋帶铐殃,會(huì)吃你吃剩下的東西海洼,會(huì)在你來(lái)大姨媽的時(shí)候給你沖紅糖水喝,會(huì)牽著你的手過(guò)馬...
    幸福小紅娘閱讀 208評(píng)論 0 0