1. Web 前端開發怎麼和後台進行相銜接
如果是前端做好了,那就是根據後端部分將數據填上了。
一種方式是後端程序員拿著你這個頁面直接改,插入數據。這個適合一些模板類的工具例如PHP,http://ASP.NET,JSP,此外還有形式上相似的比如rhtml、django模板、Velocity等等。PHP中有一個也致力於此的庫叫Smarty處理一些簡單的情形還是非常不錯的。
採用這種方式,前端做好頁面後面就幫不上忙了,只能讓後端去熟悉你前端的設計,讓後你作為前端稍微解釋一下一些細節。
一種方式是ajax取數據,也就是讓後端暴露出數據,讓前端取回來填充頁面。除了XML格式,json格式也比較流行。這種情況下是前端完成剩餘的部分,前端和後端需要約定好數據格式的細節。
這種方式的缺點是很依賴前後端的溝通,而且幾乎沒法實現測試驅動開發。
於是這種方式有各種變種,比如Ember.js,knockout.js,backbone.js這些工具使用的方式。很多時候需要給數據先設計一個schema,未必是前端或者後端寫,可能是在項目前期約定好的,前端和後端就按照預先約定好的做正確的實現就可以了,這些庫會幫你把數據在恰當的位置顯示出來,並實現一些交互功能。
請使用手機"掃一掃"x
2. 前端開發和後端開發有什麼區別
前端開發和後端開發的區別在於:
一、展示方式不同
1、前端開發主要做的是用戶所能看到的前端展示界面。
2、後端開發主要做的是邏輯功能等模塊,是用戶不可見的。
二、所用技術不同
1、前端開發用到的技術包括但不限於html5、css3、javascript、jquery、Bootstrap、Node.js 、AngularJs等技術。
2、後端開發 以java為例 主要用到的 是包括但不限於Struts spring springmvc Hibernate Http協議 Servlet Tomcat伺服器等技術。
(2)前端後台打起來了擴展閱讀:
公司對前後端人員招聘的要求:
Web前端:
1、精通HTML,能夠書寫語義合理,結構清晰,易維護的HTML結構;
2、精通CSS,能夠還原視覺設計,並兼容業界承認的主流瀏覽器;
3、熟悉JavaScript,了解ECMAScript基礎內容,掌握1到2種js框架,如JQuery;
4、對常見的瀏覽器兼容問題有清晰的理解,並有可靠的解決方案;
5、對性能有一定的要求,了解yahoo的性能優化建議,並可以在項目中有效實施;
Web後端:
1、精通jsp,servlet,javabean,JMS,EJB,Jdbc,Flex開發,或者對相關的工具、類庫以及框架非常熟悉,如Velocity,Spring,Hibernate,iBatis,OSGI等,對Web開發的模式有較深的理解;
2、練使用oracle、sqlserver、mysql等常用的資料庫系統,對資料庫有較強的設計能力;
3、熟悉maven項目配置管理工具,熟悉tomcat、jboss等應用伺服器,同時對在高並發處理情況下的負載調優有相關經驗者優先考慮;
4、精通面向對象分析和設計技術,包括設計模式、UML建模等;
5、熟悉網路編程,具有設計和開發對外API介面經驗和能力,同時具備跨平台的API規范設計以及API高效調用設計能力;
3. 前端後端是什麼
問題一:什麼是網頁的前端和後端開發 當然他們說的也不專業,前端應該是指前台的設計,包括動畫製作,圖像處理,文字編輯,版面設計等,需要掌握Dreamweaver,Flash,Fireworks,Photoshop,Freehand等工具.
後端開發應是指後台程序設計,包括資料庫設計,動態代碼編寫,一般需要掌握下面幾種語言和資料庫:ACCESS,SQL,HTML,ASP,PHP,JSP,.Net,VBscript 或Javascript.
如果你是專門搞網頁的話,你還需要掌握AJAX技術,XML,CSS等,這些都是必需的.
祝你下次面試成功.
問題二:前端開發和後端開發有什麼區別 一、要弄清區別,首先要知道前端和後端的概念:
1)Web前端: 顧名思義是來做Web的前端的。這里所說的前端泛指Web前端,也就是在Web應用中用戶可以看得見碰得著的東西。包括Web頁面的結構、Web的外觀視覺表現以及Web層面的交互實現。
2)Web後端:後端更多的是與資料庫進行交互以處理相應的業務邏輯。需要考慮的是如何實現功能、數據的存取、平台的穩定性與性能等。
二、實際的開發過程中,前端、後端開發人員所要具備的技能:
1)前端開發人員:精通JS,能熟練應用JQuery,懂CSS,能熟練運用這些知識,進行交互效果的開發。
2)後端開發人員:會寫Java代碼,會寫SQL語句,能做簡單的資料庫設計,會Spring和iBatis,懂一些設計模式等。
三、總結:
web前端分為網頁設計師、網頁美工、web前端開發工程師
首先網頁設計師是對網頁的架構、色彩以及網站的整體頁面代碼負責
網頁美工只針對UI這塊的東西,比如網站是否做的漂亮
web前端開發工程師是負責交互設計的,需要和程序員進行交互設計的配合。
web前端需要掌握的有腳本技術javascript DIV+CSS現下最流行的頁面搭建技術,ajax和jquery以及簡單的後端程序等。 後端的話可供開發的語言有 asp、php、jsp、.NET 這些後端開發語言的話搭建環境都不一樣
問題三:到底什麼是前端,後端,後台 前端是瀏覽器呈現的部分(美工設計好的網站圖片轉換成網頁html格式。),相對於前端,後台你可以理解為伺服器端(即後端)專門處理、讀取、存儲資料庫數據的部分程序。
問題四:什麼是前端,中端,後端營運 網站是依賴於互聯網存在的,只有在擁有網路的情況下才可以在線查看相關的站點、網頁等;不同的網站會分為前端與後端。
網站一般展現給大眾的則是頁面信息,這個分為前端;支撐前端展現的則是網站後端,這樣的被稱為程序,代碼類信息。
一、前端
在互聯網上網民第一眼看到的則是網站內不同的頁面,或是分支點信息頁面等。這些都總稱為前端,再者則是一些頁面的框架分配、圖片、文字、視頻、語音等整體布局,以設計、展示為准。
二、後端
這一類的信息,網民第一眼是看不到的,或是說只有一些專業的人員才能大致看到是哪一個語言編寫的、用什麼方式進行創建的、怎麼進行繼續改寫或優化網站比較好的。
網站分為也可以分為前台、後台,也就是說前面是展示類的設計:以圖、文等視覺為主的界面;後台以軟類技能或計算機語言進行的控制的;在一個網站展現給大眾前,是由後台提前創建好、編輯好再向互聯網提交後才能展現給大眾的。
在前期後端創建完成後,再由前端展現,同時由前端贏得潛在顧客、精準顧客的認可;同時後端是長期需要持續進行的,兩者共同配合進行才能讓一個網站走的更長久、在網路上擁有一個好的排名。
問題五:網站什麼的要分前端和後端的?是什麼意思? 前端 - 通常是針對瀏覽器而開發的,是在瀏覽器端運行的程序,而後端 - 針對的是伺服器,准確的來說應該是伺服器端開發。前端開發偏向於用戶體驗,比較直觀,伺服器端開發偏向於性能。兩者結合起來,是比較吃香的,可以稱之為Web開發,偏向於編程。而PS,可以看成是視覺設計方面的職能。
工資的話很難說,一般是伺服器端開發高點。另外還要看公司,如果一個公司重視前端開發,那麼這個崗位的待遇不會比伺服器端開發的人低。
培訓的話,我知道有個國信安還不錯,你可以去看看。
問題六:web前端和後端 首先前端不只有JS,還有TS,AS。前端工程師至少會PHP、ASP、java中一種。目前來說PHP相對比較熱門。前端框架現在最好能掌握Nodejs,目前比較火熱。
問題七:前端開發和後端開發有什麼區別 前端面向的是用戶編程,就是用戶可以看得到摸得到的。UI就是其中的一部分。
後端是面向服務(伺服器)編程,用戶是無須知道裡面的操作的。
舉個例子。比如簡單的登陸功能。前端的只要做好兩個文本控制項與一個按鈕控制項,並且監聽按鈕的點擊事件,將兩個文本的參數按照協議發送到伺服器端上。這就是前端要做的。
而後端,伺服器就要接收發送過來的消息並且調用資料庫驗證用戶名與密碼。成功後返回結果。
問題八:求解,什麼是前端系統,和後端系統,求通俗點的解釋?? 對於一些比較安全性要求較高、或者較復雜的系統,一般會分為前端和後端。
前端系統:一般只是操作界面,它不會直接訪問核心資料庫。而是通過調用後端系統的服務,完成業務處理。(類似Web控制台、自助查詢終端、手機APP等)
後端系統:完成核心交易處理的系統。它具備業務處理邏輯、並操作核心資料庫。以聯機介面的形式為外系統提供服務。(如:卡系統、營帳系統、認證系統等)
問題九:web前端與後端有什麼區別? web前端分為網頁設計師、網頁美工、web前端開發工程師首先網頁設計師是對網頁的架構、色彩以及網站的整體頁面代碼負責網頁美工只針對UI這塊兒的東西,比如網站是否做的漂亮web前端開發工程師是負責交互設計的。web前端分為網頁設計師、網頁美工、web前端開發工程師,首先網頁設計師是對網頁的架構、色彩以及網站的整體頁面代碼負責,網頁美工只針對UI這塊兒的東西,比如網站是否做的漂亮。web前端開發工程師是負責交互設計的,需要和程序猿進行交互設計的配合。 一位好的Web前端開發工程師在知識體繫上既要有廣度,又要有深度,所以很多大公司即使出高薪也很難招聘到理想的前端開發工程師。那麼如何系統的學習企業實用的web前端技術呢,為此建立了一個web前端的直播上課學習扣扣群,前面數字是五一四,中間的數字是一六七,最後是六七八,將數字連接起來就是了。真正想要學習的可以進入,打醬油的就不要浪費大家的時間了。現在說的重點不在於講解技術,而是更側重於對技巧的講解。技術非黑即白,只有對和錯,而技巧則見仁見智。 web前端需要掌握的有腳本技術javascript DIV+CSS現下最流行的頁面搭建技術,ajax和jquery以及簡單的後端程序等。 後端的話可供開發的語言有 asp、php、jsp、.NET 這些後端開發語言的話搭建環境都不一樣,具體如果你想學的話看是想從事前端部分還是後端程序部分。後端開發如果有一定的條件的話可以轉為軟體開發。不過要有一定的語言基礎,類似java語言。C#等。關鍵是看你的興趣愛好。。這個到後期不會區分這么細,做前端到後期也會懂一些後端的技術,反之,後端也是。在我們實際的開發過程
中,我們當前這樣定位前端、後端開發人員。 1)前端開發人員:精通JS,能熟練應用JQuery,懂CSS,能熟練運用這些知識,進行交互效果的開發。 2)後端開發人員:會寫Java代碼,會寫SQL語句,能做簡單的資料庫設計,會Spring和iBatis,懂一些設計模式等。 現在來看,我們對前後端的要求還是蠻低的,尤其是後端,新員工經過培訓之後都是可以參與到後端開發的,沒有太高的技術門檻,唯一需要做的就是先變成熟練工種,這個階段沒有涉及到設計模式、架構、效率等一些列問題。 還是先google一下,看看網上對Web前端開發、Web後端開發分別是什麼? Web前端: 顧名思義是來做Web的前端的。我們這里所說的前端泛指Web前端,也就是在Web應用中用戶可以看得見碰得著的東西。包括Web頁面的結構、Web的外觀視覺表現以及Web層面的交互實現。 Web後端:後端更多的是與資料庫進行交互以處理相應的業務邏輯。需要考慮的是如何實現功能、數據的存取、平台的穩定性與性能等
問題十:網頁設計前端和後端的區別?越詳細越好。 我本身是做軟體前端開發的,以前做過兩年的網頁設計,以我個人的理解來說一點淺見好了,前端主要的工作是頁面或界面的設計製作、html切圖、動態交互等,而後端准確的說是後台,主要工作是整個網站或者軟體的功能實現,通俗點講就是程序員,現在普遍是兩個工種分開來了,因為一個人做的話反而效率不高,如果你是想做這一行,那麼我個人是建議你做程序員拉倒,雖然程序員工作量可能會比設計多,但做設計太費腦子了,程序員主要是一些邏輯性的事情,很多代碼都有現成的,大部分工作就是復制粘貼而已,而且客戶看東西首先是看前端咋樣,這就考驗設計師水平了,最後就是重點了,程序員的普遍工資要比設計高,當然,設計師也有高的,但無一不是技術過硬和工作經驗足夠的。
4. web後端和前端是怎麼連接的
web後端和前端是怎麼連接的
WEB後端和WEB前端可以通過 前端模板引擎 與 後端模板引擎 進行連接。
後端模板引擎:
WEB前端開發人員開發好前端靜態頁面,然後交給WEB後端開發人員,他們再利用後端引擎模板(比如:freemarker)把前端頁面與後端數據進行連接,形參一個動態頁面。
前端模板引擎:
描述成前端模板引擎可能不太對,但是比較好理解吧。當前比較流行的Vue.js、Angular.js、React.js 等MVVM前端框架都自帶了前端模板引擎。
WEB前端人員與WEB後端人員一起協定好數據介面格式(請求地址、數據格式、數據欄位等),然後WEB前端人員與WEB後端人員同時進行項目的開發,WEB前端人員通過AJAX的方式從WEB後端獲取到前端頁面的相關JSON數據,然後通過MVVM前端框架把JSON數據渲染到頁面裡面,最終形成了一個動態頁面。
網站數據處理主要分為三層。
第一,表示層,這部分可以用HTML代碼,CSS/Javascript代碼來實現等。通過前端代碼可以實現網頁的布局和設計。這層又可以稱為顯示層。也就是你用瀏覽器打開能看到的網頁。
第二層,是業務層,這層是負責處理數據的。常用的代碼語言有PHP,JSP,Java等。通過這些後台處理語言的演算法來處理前台傳回的數據。必要的時候進行操作資料庫,然後把結果返回給前端網頁。
第三層,是數據層,這個就是資料庫,用來存儲數據的。通過業務層的操作可以實現增刪改資料庫的操作。
舉個例子就是這樣,比方說你在網頁上填一個表格然後提交會有以下幾種數據傳輸經過:
①你接觸到的是這個網頁是屬於表示層,這個網頁一般由HTML標簽結合CSS/JAVASCRIPT來實現的。 這時候你要先填入數據。
②然後你按提交觸發後台處理機制,這時候數據會傳到後台的代碼進行處理。這部分代碼根據不同網站可以使PHP,JSP,JAVA等。 代碼根據程序員預設的演算法將收到的數據進行處理之後會相應的對資料庫進行操作,存儲數據等。
③成功操作完資料庫之後,業務層的代碼會再向表示層也就是顯示器端傳回一個指令通知你表格填寫成功。
這就是基本的網站數據交換邏輯了
後端會暴露出一個處理數據邏輯的介面(api),然後哦前端通過js像後端暴露的api發起請求過程可攜帶參數,然後後端接到請求後會返回數據給前端,前端拿到數據後會渲染在頁面上
治安監控的前端是怎麼連接的?
固定攝像機前端有和電源(220V轉12V)全方位像像機前端一根視頻線(和主機採集卡連接)一根電源線220V(連接解碼器)一根通訊線(連接主機上的碼轉)
後端thinkphp和前端vue怎麼協調
hinkphp作為服務端,為客戶端提供數據。而Vue是客戶端的一個JavaScript框架。便於我們對頁面進行處理。
一般情況下,vue通過非同步請求來獲取數據。由於實例化vue時已經將相關的變數、模板等定義好了。
當獲取到thinkphp回傳的數據後,將會自動的把數據對應的呈現在網頁上。
php在web開發中技術含量排第三(jsp,.在前),但由於php簡單,開發周期短,運行速度快,很快就成為中小型網站的首選技術,像CMS全球超過70%都是php的.再說大型網站現在也很少,所以,學習php找工作要容易得多,自己想接私單也容易拿下!
就是這樣的,我剛剛在後盾人知道的那邊有詳細的教學視頻.,可以給你學習
thinkphp作為服務端,為客戶端提供數據。而Vue是客戶端的一個JavaScript框架。便於我們對頁面進行處理。
一般情況下,vue通過非同步請求來獲取數據。由於實例化vue時已經將相關的變數、模板等定義好了。
當獲取到thinkphp回傳的數據後,將會自動的把數據對應的呈現在網頁上。 你看過後很簡單吧以後不會可以向我一樣經常到後盾人找找相關教材看看就會了,希望能幫到你,給個採納吧謝謝(⁄ ⁄•⁄ω⁄•⁄ ⁄)
thinkphp 設計服務端,全restful api的規范就行設計(其實只要返回json或xml就可以),
vue-resouve只是一個請求庫,和jquery 的 ajax 是大同小異的
5. 實際中前後端開發數據交互是怎麼樣的
1.前端請求數據URL由誰來寫?
在開發中,URL主要是由後台來寫的,寫好了給前端開發者.如果後台在查詢數據,需要藉助查詢條件才能查詢到前端需要的數據時,這時後台會要求前端提供相關的查詢參數,這里的查詢參數也就是URL請求的參數。
2.介面文檔主要由誰來寫?
介面文檔也是主要由後台開發者來寫的,因為直接跟數據打交道的就是後台,後台是最清楚,資料庫裡面有什麼數據,能返回什麼數據.前端開發只是數據的被動接受者.所以介面文檔也主要是由後台來完成的,前端只是介面文檔的使用者,使用過程中,發現返回的數據不對,則需要跟後台進行商量,由後台來修改.切記 前端不要隨意更改介面文檔,除非在取得後台開發人員的同意的情況下.總的來講,介面文檔主要由後台來設計,修改,前端開發者起到了輔助的作用。
3.前端開發與後台交互的數據格式主要是什麼?
主要是JSON
XML現在用的不多
4.前端開發的後台交互原理?
在項目的時候,我們前後端會大概說一下介面地址,前端請求的參數,後端返回的參數,然後大家就開始寫,寫的差不多的時候,大家調一下介面看一下返回的數據,沒問題就可以了。
5.前端請求參數的形式
GET和POST兩種方式
對安全性不高 採用get方便
post要比get安全
GET - 從指定的伺服器中獲取數據
POST - 提交數據給指定的伺服器處理
6.前端應該告知後台哪些有效信息,後台才能返回前端想的數據的呢?
先將要展示的頁面內容進行模塊劃分,將模塊的內容提取出來,以及方便前端的一些標志值等,將所有想要的內容和邏輯告知後端,
後端就會去資料庫裡面去查找相應的數據表中去獲得相應的內容,或者圖片地址信息。
URL中的參數主要是根據後台需要,
如果後台需要一個參數作為查詢的輔助條件 前端在URL數據請求時就傳遞參數。
參數前面?
幾個參數中間&
7.我們應該怎麼把頁面這些信息有效傳達給後台,以及後台是如何獲取到這些數據?
總的來講:所有前端請求的URL後面的參數,都是輔助後台數據查詢的.如果不需要參數,那麼後台就會直接給個URL給前端。
8.前端應該如何回拒一些本不屬於自己做的一些功能需求或任務?
在與後台打交道中,我們經常遇到這種情況,有時候明明後台來處理某個事件很簡單,後台非要你來做,這時候我們應該懂得去回絕他。
原則:前端就是負責把數據展示在頁面上
發揮:這就需要我們對一個需求,一個任務的要有清晰認識了,如果對任務含糊不清,自己都沒搞明白,你只能受後台擺布了.最後也會因為任務沒有完成而備受責難了。
9.當前端在調用數據介面時,發現有些數據不是我們想要的,那麼前端應該怎麼辦呢或者怎麼跟後台講呢?
首先要把請求的URL和返回的數據以及在頁面的展示的情況給跟後台看,這樣有理有據,後台開發人員是不會說什麼的,否則,後台會很不耐煩的,甚至罵你的可能都有,本身做後台比較難,尤其在查詢數據,取數據,封裝數據方面都比較難處理。
10.為什麼需要在請求的時候傳入參數?
因為後台在查詢資料庫的時候需要條件查詢。
6. 前後端分離方案以及技術選型
作者:關開發
一.什麼是前後端分離?
理解前後端分離大概可以從3個方面理解:
1. 交互形式
2. 代碼組織形式
3. 開發模式與流程
1.1 交互形式
前後端不分離
後端將數據和頁面組裝、渲染好了之後,向瀏覽器輸出最終的html;瀏覽器接收到後會解析html,解析引入的css、執行js腳本,完成最終的頁面展示。
前後端分離
後端只需要和前端約定好接收以及返回的數據格式(一般用JSON格式),向前端提供API介面。前端就可以通過HTTP請求調用API的方式進行交互。前端獲取到數據後,進行頁面組裝、渲染,最終在瀏覽器呈現。
1.2 代碼組織形式
前後端不分離
在web應用早期的時候,前端頁面以及後台業務數據處理的代碼都放在一個工程下,甚至放在同一目錄下,前端頁面夾雜著後端代碼。前、後端開發工程師都需要把整套代碼導入開發工具才能開發。此階段下前後端代碼以及工作耦合度太高,前端不能獨立開發和測試,後端人員也要依賴前端完成頁面後才能完成開發。最糟糕的情況是前端工程師需要會後端模板技術(jsp),後端工程師還要會點前端技術,需要口頭說明頁面數據介面,才能配合完成開發。否則前端只能當一個「切圖仔」,只輸出HTML、CSS、以及很少量與業務邏輯無關的js;然後由後端轉化為後端jsp,並且還要寫業務的js代碼。
前後端分離
前後端代碼放在不同的工程下,前端代碼可以獨立開發,通過mock/easy-mock技術模擬後端API服務可以獨立運行、測試;後端代碼也可以獨立開發,運行、測試,通過swagger技術能自動生成API文檔供前端閱讀,還可以進行自動化介面測試,保證API的可用性,降低集成風險。
1.3 開發模式與流程
前後端不分離
在項目開發階段,前端根據原型和UI設計稿,編寫HTML、CSS以及少量與業務無關的js(純效果那些),完成後交給後台人員,後台人員將HTML轉為jsp,並通過JSP的模板語法進行數據綁定以及一些邏輯操作。後台完成後,將全部代碼打包,包含前端代碼、後端代碼打成一個war,然後部署到同一台伺服器運行。頂多做一下動靜分離,也就是把圖片、css、js分開部署到nginx。
具體開發流程如下:圖略
前後端分離
實現前後端分離之後,前端根據原型和UI設計稿編寫HTML、CSS以及少量與業務無關的js(純效果那些),後端也同時根據原型進行API設計,並與前端協定API數據規范。等到後台API完成,或僅僅是API數據規范設定完成之後。前端即可通過HTTP調用API,或通過mock數據完成數據組裝以及業務邏輯編寫。前後端可以並行,或者前端先行於後端開發了。
具體開發流程如下:圖略
二、前後端分離的好處與壞處。
從上面3個方面對比了之後,前後端分離架構和傳統的web架構相比,有很大的變化,看起來好處多多。到底是分還是不分,我們還是要理性分析是否值得才去做。
從目前應用軟體開發的發展趨勢來看,主要有兩方面需要注意:
· 越來越注重用戶體驗,隨著互聯網的發展,開始多終端化。
· 大型應用架構模式正在向雲化、微服務化發展。
我們主要通過前後端分離架構,為我們帶來以下四個方面的提升:
· 為優質產品打造精益團隊
通過將開發團隊前後端分離化,讓前後端工程師只需要專注於前端或後端的開發工作,是的前後端工程師實現自治,培養其獨特的技術特性,然後構建出一個全棧式的精益開發團隊。
· 提升開發效率
前後端分離以後,可以實現前後端代碼的解耦,只要前後端溝通約定好應用所需介面以及介面參數,便可以開始並行開發,無需等待對方的開發工作結束。與此同時,即使需求發生變更,只要介面與數據格式不變,後端開發人員就不需要修改代碼,只要前端進行變動即可。如此一來整個應用的開發效率必然會有質的提升。
· 完美應對復雜多變的前端需求
如果開發團隊能完成前後端分離的轉型,打造優秀的前後端團隊,開發獨立化,讓開發人員做到專注專精,開發能力必然會有所提升,能夠完美應對各種復雜多變的前端需求。
· 增強代碼可維護性
前後端分離後,應用的代碼不再是前後端混合,只有在運行期才會有調用依賴關系。應用代碼將會變得整潔清晰,不論是代碼閱讀還是代碼維護都會比以前輕松。
那麼前後端分離有什麼不好的地方嗎?我目前是沒有想到,除非你說會增加前端團隊的配備,後端工程師會變的不全能。。。
二、前後端分離架構方案。
實現前後端分離,主要是前端的技術架構變化較大,後端主要變為restfull 風格API,然後加上Swagger技術自動生成在線介面文檔就差不多了。
對於目前用於前後端分離方案的前端技術架構主要有兩種:
· 傳統SPA
· 服務端渲染SSR
2.1 傳統SPA
傳統SPA指的是單頁面應用,也就是整個網站只有一個頁面,所有功能都通過這一個頁面來呈現。因為一個人的肉眼,某一個時間點看一個頁面,既然如此何必要不同功能做多個頁面呢?只保留一個頁面作為模板,然後通過路由跳轉來更新這個模板頁面的內容不就可以了嗎?確實如此,現在通過reac全家桶、tvue全家桶,模塊化、路由、wabpack等技術輕而易舉就能實現一個單頁面應用。
單頁面應用的運行流程
1.用戶通過瀏覽器訪問網站url
2.單頁面的html文件(index.html)被下載到瀏覽器,接著下載html裡面引用的css,js。
3.css,js下載到瀏覽器完成之後,瀏覽器開始解析執行js向後端服務非同步請求數據。
4.請求數據完成後,進行數據綁定、渲染,最終在用戶瀏覽器呈現完整的頁面。
2.2 服務端渲染
服務端渲染的方案指的是數據綁定,渲染等工作都放在服務端完成,服務端向瀏覽器輸出最終的html。大家看完這個是不是有個疑問,這不是又回到了前後端不分離的時代了嗎?答案是否定的,因為這里的服務端是用來執行前端數據綁定、渲染的,也就是把瀏覽器的一部分工作分擔到了服務端。而目前具備這只種能力的服務端是NodeJs服務端。
它的原理其實就是在瀏覽器與前端代碼中間插入了一個NodeJs服務端。瀏覽器請求前端頁面時,會先經過NodeJS服務端,由NodeJs去讀取前端頁面,並執行非同步後端API,獲取到數據後進行頁面數據綁定,渲染等工作,完成一個最終的html然後返回瀏覽器,最後瀏覽器進行展示。
服務端渲染應用的運行流程:
1.用戶通過瀏覽器訪問網站url
2.NodeJS服務端接收到請求,讀取到對應的前端html,css,js。
3.NodeJS解析執行js向後端API非同步請求數據。
4.NodeJs請求數據完成之後,進行數據綁定、渲染,得到一個最終的html。
5.NodeJs向瀏覽器輸出html,瀏覽器進行展示。
PS:其實本質就是把前端編寫成一個nodeJs的服務端web應用。實施服務端渲染後,我們最終運行的是一個Nodejs服務端應用。而單頁面應用是把靜態頁面部署到靜態資源伺服器進行運行。
看到這里,你是否又有疑問,為什麼要這么麻煩搞服務端渲染呢?
2.3 SPA與服務端渲染方案對比
SPA的優點是開發簡單,部署簡單;缺點是首次載入較慢,需要較好的網路,不友好的SEO。
so,以下就是使用服務端渲染的理由了(摘取vue官方說法):
與傳統 SPA (單頁應用程序 (Single-Page Application)) 相比,伺服器端渲染 (SSR) 的優勢主要在於:
· 更好的 SEO,由於搜索引擎爬蟲抓取工具可以直接查看完全渲染的頁面。
請注意,截至目前,Google 和 Bing 可以很好對同步 JavaScript 應用程序進行索引。在這里,同步是關鍵。如果你的應用程序初始展示 loading 菊花圖,然後通過 Ajax 獲取內容,抓取工具並不會等待非同步完成後再行抓取頁面內容。也就是說,如果 SEO 對你的站點至關重要,而你的頁面又是非同步獲取內容,則你可能需要伺服器端渲染(SSR)解決此問題。
· 更快的內容到達時間 (time-to-content),特別是對於緩慢的網路情況或運行緩慢的設備。
無需等待所有的 JavaScript 都完成下載並執行,才顯示伺服器渲染的標記,所以你的用戶將會更快速地看到完整渲染的頁面。通常可以產生更好的用戶體驗,並且對於那些「內容到達時間(time-to-content) 與轉化率直接相關」的應用程序而言,伺服器端渲染 (SSR) 至關重要。
使用伺服器端渲染 (SSR) 時還需要有一些權衡之處:
· 開發條件所限。瀏覽器特定的代碼,只能在某些生命周期鉤子函數 (lifecycle hook) 中使用;一些外部擴展庫 (external library) 可能需要特殊處理,才能在伺服器渲染應用程序中運行。
· 涉及構建設置和部署的更多要求。與可以部署在任何靜態文件伺服器上的完全靜態單頁面應用程序 (SPA) 不同,伺服器渲染應用程序,需要處於 Node.js server 運行環境。
· 更多的伺服器端負載。在 Node.js 中渲染完整的應用程序,顯然會比僅僅提供靜態文件的 server 更加大量佔用 CPU 資源 (CPU-intensive - CPU 密集),因此如果你預料在高流量環境 (high traffic) 下使用,請准備相應的伺服器負載,並明智地採用緩存策略。
以vue為例,實施服務端渲染可以查看官方指南: https://ssr.vuejs.org ,或選擇Nuxt.js
2.4 預渲染技術
如果你調研伺服器端渲染 (SSR) 只是用來改善少數營銷頁面(例如 /, /about, /contact 等)的 SEO,那麼你可能需要預渲染。無需使用 web 伺服器實時動態編譯 HTML,而是使用預渲染方式,在構建時 (build time) 簡單地生成針對特定路由的靜態 HTML 文件。優點是設置預渲染更簡單,並可以將你的前端作為一個完全靜態的站點。
如果你使用 webpack,你可以使用 prerender-spa-plugin 輕松地添加預渲染。它已經被 Vue 應用程序廣泛測試 - 事實上,作者是 Vue 核心團隊的成員。
prerender-spa-plugin: https://github.com/chrisvfritz/prerender-spa-plugin
三、前後端分離技術選型
- artTemplate + bootstrap(不推薦, 不算完全前後端分離)
- vue全家桶(推薦)
- react全家桶 (推薦,生態全)
7. 知乎 怎麼把前端和後台連接起來
1、前端和後端之所以需要對接,是因為前端頁面只負責提供視圖沒有內容。
2、而後端只提供內容,兩者所謂的對接,就是把後端的內容放在前端頁面預留出來的位置上。(雖然說是前端後端,但這一對接實際發生在伺服器端)
3、所以伺服器端進行的活動如下:接收用戶請求——》找到負責處理的程序——》處理程序找到要傳輸給用戶的前端頁面——》該前端頁面留出位置——》後端到資料庫取數據——》後端把數據放在前端留出來的位置上——》結合成真正用戶看到的html文件——》傳輸給用戶。
8. 底什麼是前端後端,後台
我說的是軟體技術開發上的前端、後端、後台。不一定專業,但供參考。
前端:一般指客戶端。就是用戶使用的軟體。如QQ,微信操作的軟體均屬於前端。
後端:一般指服務端。就是構建整套互聯網服務的部分。如QQ,微信都有IM伺服器,就屬於後端。
後台:一般指管理員可操作的一個平台。不同產品後台不一樣。可能是查看數據的後台,也有可能是監管用戶狀態的後台。一般呈現方式是一個網頁。不過也有做成單獨產品的後台。
9. 前端後端怎麼連接起來
前端調用後端介面無外乎六種方法,如下:
1、打開vs,創建空的asp.net mvc演示項目【WebMVC】
(1)依次點擊【文件】->【新建】->【項目】;
(2)在【新建項目】界面選擇【Web】->【ASP.NET Web 應用程序(.NET Framework)】,輸入名稱,選擇框架至少4.5版本,點擊【確定】按鈕;
(3)選擇【空】->【MVC】->【確定】 ;
(4)創建好了項目。
2、在項目中
(1)在Controllers文件夾上點擊滑鼠右鍵,依次選擇【添加】->【控制器】,即可完成HomeController的創建;
(2)在Controller的Index方法內,點擊滑鼠右鍵,選擇【添加視圖】;
(3)在項目中添加文件夾【Content】並添加jquery源文件;
(4)在Index頁面添加jquery的引用。
3、在Index頁面中添加一個輸入文本框,一個按鈕,以及顯示結果的dom。
4、在HomeController中添加新的方法,用於接收前台傳入的參數,組裝後返回。
5、在Index頁面,添加Jquery的ajax方式,調用後台介面,返回結果的處理代碼。
6、在vs中,按F5調試運行結果,如下:
(1)在文本框中輸入內容;
(2)點擊按鈕,調用介面,並將返回值顯示在界面;
(3)如果要提交大量數據,或者敏感數據,請修改ajax的type方式,這樣參數就不會在url地址欄中顯示了。