前端技術(shù)方案文檔模板(前端設(shè)計(jì)方案)
本篇文章給大家談?wù)勄岸思夹g(shù)方案文檔模板,以及前端設(shè)計(jì)方案對應(yīng)的知識點(diǎn),希望對各位有所幫助,不要忘了收藏本站喔。
本文目錄一覽:
- 1、前端開發(fā)的技術(shù)文檔怎么寫
- 2、前后端分離方案以及技術(shù)選型
- 3、求一份APP前端設(shè)計(jì)(包括從流程圖到效果圖,到前端開發(fā)實(shí)現(xiàn))的開發(fā)時(shí)間評估文檔模板
前端開發(fā)的技術(shù)文檔怎么寫
可以從項(xiàng)目背景,功能模塊,目錄結(jié)構(gòu),接口列表來寫,還可以配合jsdoc自動生成各個(gè)js文件的詳細(xì)文檔
前后端分離方案以及技術(shù)選型
作者:關(guān)開發(fā)
一.什么是前后端分離?
理解前后端分離大概可以從3個(gè)方面理解:
1. 交互形式
2. 代碼組織形式
3. 開發(fā)模式與流程
1.1 交互形式
前后端不分離
后端將數(shù)據(jù)和頁面組裝、渲染好了之后,向?yàn)g覽器輸出最終的html;瀏覽器接收到后會解析html,解析引入的css、執(zhí)行js腳本,完成最終的頁面展示。
前后端分離
后端只需要和前端約定好接收以及返回的數(shù)據(jù)格式(一般用JSON格式),向前端提供API接口。前端就可以通過HTTP請求調(diào)用API的方式進(jìn)行交互。前端獲取到數(shù)據(jù)后,進(jìn)行頁面組裝、渲染,最終在瀏覽器呈現(xiàn)。
1.2 代碼組織形式
前后端不分離
在web應(yīng)用早期的時(shí)候,前端頁面以及后臺業(yè)務(wù)數(shù)據(jù)處理的代碼都放在一個(gè)工程下,甚至放在同一目錄下,前端頁面夾雜著后端代碼。前、后端開發(fā)工程師都需要把整套代碼導(dǎo)入開發(fā)工具才能開發(fā)。此階段下前后端代碼以及工作耦合度太高,前端不能獨(dú)立開發(fā)和測試,后端人員也要依賴前端完成頁面后才能完成開發(fā)。最糟糕的情況是前端工程師需要會后端模板技術(shù)(jsp),后端工程師還要會點(diǎn)前端技術(shù),需要口頭說明頁面數(shù)據(jù)接口,才能配合完成開發(fā)。否則前端只能當(dāng)一個(gè)“切圖仔”,只輸出HTML、CSS、以及很少量與業(yè)務(wù)邏輯無關(guān)的js;然后由后端轉(zhuǎn)化為后端jsp,并且還要寫業(yè)務(wù)的js代碼。
前后端分離
前后端代碼放在不同的工程下,前端代碼可以獨(dú)立開發(fā),通過mock/easy-mock技術(shù)模擬后端API服務(wù)可以獨(dú)立運(yùn)行、測試;后端代碼也可以獨(dú)立開發(fā),運(yùn)行、測試,通過swagger技術(shù)能自動生成API文檔供前端閱讀,還可以進(jìn)行自動化接口測試,保證API的可用性,降低集成風(fēng)險(xiǎn)。
1.3 開發(fā)模式與流程
前后端不分離
在項(xiàng)目開發(fā)階段,前端根據(jù)原型和UI設(shè)計(jì)稿,編寫HTML、CSS以及少量與業(yè)務(wù)無關(guān)的js(純效果那些),完成后交給后臺人員,后臺人員將HTML轉(zhuǎn)為jsp,并通過JSP的模板語法進(jìn)行數(shù)據(jù)綁定以及一些邏輯操作。后臺完成后,將全部代碼打包,包含前端代碼、后端代碼打成一個(gè)war,然后部署到同一臺服務(wù)器運(yùn)行。頂多做一下動靜分離,也就是把圖片、css、js分開部署到nginx。
具體開發(fā)流程如下:圖略
前后端分離
實(shí)現(xiàn)前后端分離之后,前端根據(jù)原型和UI設(shè)計(jì)稿編寫HTML、CSS以及少量與業(yè)務(wù)無關(guān)的js(純效果那些),后端也同時(shí)根據(jù)原型進(jìn)行API設(shè)計(jì),并與前端協(xié)定API數(shù)據(jù)規(guī)范。等到后臺API完成,或僅僅是API數(shù)據(jù)規(guī)范設(shè)定完成之后。前端即可通過HTTP調(diào)用API,或通過mock數(shù)據(jù)完成數(shù)據(jù)組裝以及業(yè)務(wù)邏輯編寫。前后端可以并行,或者前端先行于后端開發(fā)了。
具體開發(fā)流程如下:圖略
二、前后端分離的好處與壞處。
從上面3個(gè)方面對比了之后,前后端分離架構(gòu)和傳統(tǒng)的web架構(gòu)相比,有很大的變化,看起來好處多多。到底是分還是不分,我們還是要理性分析是否值得才去做。
從目前應(yīng)用軟件開發(fā)的發(fā)展趨勢來看,主要有兩方面需要注意:
· 越來越注重用戶體驗(yàn),隨著互聯(lián)網(wǎng)的發(fā)展,開始多終端化。
· 大型應(yīng)用架構(gòu)模式正在向云化、微服務(wù)化發(fā)展。
我們主要通過前后端分離架構(gòu),為我們帶來以下四個(gè)方面的提升:
· 為優(yōu)質(zhì)產(chǎn)品打造精益團(tuán)隊(duì)
通過將開發(fā)團(tuán)隊(duì)前后端分離化,讓前后端工程師只需要專注于前端或后端的開發(fā)工作,是的前后端工程師實(shí)現(xiàn)自治,培養(yǎng)其獨(dú)特的技術(shù)特性,然后構(gòu)建出一個(gè)全棧式的精益開發(fā)團(tuán)隊(duì)。
· 提升開發(fā)效率
前后端分離以后,可以實(shí)現(xiàn)前后端代碼的解耦,只要前后端溝通約定好應(yīng)用所需接口以及接口參數(shù),便可以開始并行開發(fā),無需等待對方的開發(fā)工作結(jié)束。與此同時(shí),即使需求發(fā)生變更,只要接口與數(shù)據(jù)格式不變,后端開發(fā)人員就不需要修改代碼,只要前端進(jìn)行變動即可。如此一來整個(gè)應(yīng)用的開發(fā)效率必然會有質(zhì)的提升。
· 完美應(yīng)對復(fù)雜多變的前端需求
如果開發(fā)團(tuán)隊(duì)能完成前后端分離的轉(zhuǎn)型,打造優(yōu)秀的前后端團(tuán)隊(duì),開發(fā)獨(dú)立化,讓開發(fā)人員做到專注專精,開發(fā)能力必然會有所提升,能夠完美應(yīng)對各種復(fù)雜多變的前端需求。
· 增強(qiáng)代碼可維護(hù)性
前后端分離后,應(yīng)用的代碼不再是前后端混合,只有在運(yùn)行期才會有調(diào)用依賴關(guān)系。應(yīng)用代碼將會變得整潔清晰,不論是代碼閱讀還是代碼維護(hù)都會比以前輕松。
那么前后端分離有什么不好的地方嗎?我目前是沒有想到,除非你說會增加前端團(tuán)隊(duì)的配備,后端工程師會變的不全能。。。
二、前后端分離架構(gòu)方案。
實(shí)現(xiàn)前后端分離,主要是前端的技術(shù)架構(gòu)變化較大,后端主要變?yōu)閞estfull 風(fēng)格API,然后加上Swagger技術(shù)自動生成在線接口文檔就差不多了。
對于目前用于前后端分離方案的前端技術(shù)架構(gòu)主要有兩種:
· 傳統(tǒng)SPA
· 服務(wù)端渲染SSR
2.1 傳統(tǒng)SPA
傳統(tǒng)SPA指的是單頁面應(yīng)用,也就是整個(gè)網(wǎng)站只有一個(gè)頁面,所有功能都通過這一個(gè)頁面來呈現(xiàn)。因?yàn)橐粋€(gè)人的肉眼,某一個(gè)時(shí)間點(diǎn)看一個(gè)頁面,既然如此何必要不同功能做多個(gè)頁面呢?只保留一個(gè)頁面作為模板,然后通過路由跳轉(zhuǎn)來更新這個(gè)模板頁面的內(nèi)容不就可以了嗎?確實(shí)如此,現(xiàn)在通過reac全家桶、tvue全家桶,模塊化、路由、wabpack等技術(shù)輕而易舉就能實(shí)現(xiàn)一個(gè)單頁面應(yīng)用。
單頁面應(yīng)用的運(yùn)行流程
1.用戶通過瀏覽器訪問網(wǎng)站url
2.單頁面的html文件(index.html)被下載到瀏覽器,接著下載html里面引用的css,js。
3.css,js下載到瀏覽器完成之后,瀏覽器開始解析執(zhí)行js向后端服務(wù)異步請求數(shù)據(jù)。
4.請求數(shù)據(jù)完成后,進(jìn)行數(shù)據(jù)綁定、渲染,最終在用戶瀏覽器呈現(xiàn)完整的頁面。
2.2 服務(wù)端渲染
服務(wù)端渲染的方案指的是數(shù)據(jù)綁定,渲染等工作都放在服務(wù)端完成,服務(wù)端向?yàn)g覽器輸出最終的html。大家看完這個(gè)是不是有個(gè)疑問,這不是又回到了前后端不分離的時(shí)代了嗎?答案是否定的,因?yàn)檫@里的服務(wù)端是用來執(zhí)行前端數(shù)據(jù)綁定、渲染的,也就是把瀏覽器的一部分工作分擔(dān)到了服務(wù)端。而目前具備這只種能力的服務(wù)端是NodeJs服務(wù)端。
它的原理其實(shí)就是在瀏覽器與前端代碼中間插入了一個(gè)NodeJs服務(wù)端。瀏覽器請求前端頁面時(shí),會先經(jīng)過NodeJS服務(wù)端,由NodeJs去讀取前端頁面,并執(zhí)行異步后端API,獲取到數(shù)據(jù)后進(jìn)行頁面數(shù)據(jù)綁定,渲染等工作,完成一個(gè)最終的html然后返回瀏覽器,最后瀏覽器進(jìn)行展示。
服務(wù)端渲染應(yīng)用的運(yùn)行流程:
1.用戶通過瀏覽器訪問網(wǎng)站url
2.NodeJS服務(wù)端接收到請求,讀取到對應(yīng)的前端html,css,js。
3.NodeJS解析執(zhí)行js向后端API異步請求數(shù)據(jù)。
4.NodeJs請求數(shù)據(jù)完成之后,進(jìn)行數(shù)據(jù)綁定、渲染,得到一個(gè)最終的html。
5.NodeJs向?yàn)g覽器輸出html,瀏覽器進(jìn)行展示。
PS:其實(shí)本質(zhì)就是把前端編寫成一個(gè)nodeJs的服務(wù)端web應(yīng)用。實(shí)施服務(wù)端渲染后,我們最終運(yùn)行的是一個(gè)Nodejs服務(wù)端應(yīng)用。而單頁面應(yīng)用是把靜態(tài)頁面部署到靜態(tài)資源服務(wù)器進(jìn)行運(yùn)行。
看到這里,你是否又有疑問,為什么要這么麻煩搞服務(wù)端渲染呢?
2.3 SPA與服務(wù)端渲染方案對比
SPA的優(yōu)點(diǎn)是開發(fā)簡單,部署簡單;缺點(diǎn)是首次加載較慢,需要較好的網(wǎng)絡(luò),不友好的SEO。
so,以下就是使用服務(wù)端渲染的理由了(摘取vue官方說法):
與傳統(tǒng) SPA (單頁應(yīng)用程序 (Single-Page Application)) 相比,服務(wù)器端渲染 (SSR) 的優(yōu)勢主要在于:
· 更好的 SEO,由于搜索引擎爬蟲抓取工具可以直接查看完全渲染的頁面。
請注意,截至目前,Google 和 Bing 可以很好對同步 JavaScript 應(yīng)用程序進(jìn)行索引。在這里,同步是關(guān)鍵。如果你的應(yīng)用程序初始展示 loading 菊花圖,然后通過 Ajax 獲取內(nèi)容,抓取工具并不會等待異步完成后再行抓取頁面內(nèi)容。也就是說,如果 SEO 對你的站點(diǎn)至關(guān)重要,而你的頁面又是異步獲取內(nèi)容,則你可能需要服務(wù)器端渲染(SSR)解決此問題。
· 更快的內(nèi)容到達(dá)時(shí)間 (time-to-content),特別是對于緩慢的網(wǎng)絡(luò)情況或運(yùn)行緩慢的設(shè)備。
無需等待所有的 JavaScript 都完成下載并執(zhí)行,才顯示服務(wù)器渲染的標(biāo)記,所以你的用戶將會更快速地看到完整渲染的頁面。通??梢援a(chǎn)生更好的用戶體驗(yàn),并且對于那些「內(nèi)容到達(dá)時(shí)間(time-to-content) 與轉(zhuǎn)化率直接相關(guān)」的應(yīng)用程序而言,服務(wù)器端渲染 (SSR) 至關(guān)重要。
使用服務(wù)器端渲染 (SSR) 時(shí)還需要有一些權(quán)衡之處:
· 開發(fā)條件所限。瀏覽器特定的代碼,只能在某些生命周期鉤子函數(shù) (lifecycle hook) 中使用;一些外部擴(kuò)展庫 (external library) 可能需要特殊處理,才能在服務(wù)器渲染應(yīng)用程序中運(yùn)行。
· 涉及構(gòu)建設(shè)置和部署的更多要求。與可以部署在任何靜態(tài)文件服務(wù)器上的完全靜態(tài)單頁面應(yīng)用程序 (SPA) 不同,服務(wù)器渲染應(yīng)用程序,需要處于 Node.js server 運(yùn)行環(huán)境。
· 更多的服務(wù)器端負(fù)載。在 Node.js 中渲染完整的應(yīng)用程序,顯然會比僅僅提供靜態(tài)文件的 server 更加大量占用 CPU 資源 (CPU-intensive - CPU 密集),因此如果你預(yù)料在高流量環(huán)境 (high traffic) 下使用,請準(zhǔn)備相應(yīng)的服務(wù)器負(fù)載,并明智地采用緩存策略。
以vue為例,實(shí)施服務(wù)端渲染可以查看官方指南: ,或選擇Nuxt.js
2.4 預(yù)渲染技術(shù)
如果你調(diào)研服務(wù)器端渲染 (SSR) 只是用來改善少數(shù)營銷頁面(例如 /, /about, /contact 等)的 SEO,那么你可能需要預(yù)渲染。無需使用 web 服務(wù)器實(shí)時(shí)動態(tài)編譯 HTML,而是使用預(yù)渲染方式,在構(gòu)建時(shí) (build time) 簡單地生成針對特定路由的靜態(tài) HTML 文件。優(yōu)點(diǎn)是設(shè)置預(yù)渲染更簡單,并可以將你的前端作為一個(gè)完全靜態(tài)的站點(diǎn)。
如果你使用 webpack,你可以使用 prerender-spa-plugin 輕松地添加預(yù)渲染。它已經(jīng)被 Vue 應(yīng)用程序廣泛測試 - 事實(shí)上,作者是 Vue 核心團(tuán)隊(duì)的成員。
prerender-spa-plugin:
三、前后端分離技術(shù)選型
- artTemplate + bootstrap(不推薦, 不算完全前后端分離)
- vue全家桶(推薦)
- react全家桶 (推薦,生態(tài)全)
求一份APP前端設(shè)計(jì)(包括從流程圖到效果圖,到前端開發(fā)實(shí)現(xiàn))的開發(fā)時(shí)間評估文檔模板
極其流行,同樣也是競爭力極其大的一種商業(yè)模式。雖然國內(nèi)軟件開發(fā)公司都發(fā)展壯大起來了,但是各地軟件開發(fā)公司的實(shí)力及資質(zhì)仍然參差不齊。下面為大家介紹下近期國內(nèi)軟件開發(fā)公司的排名匯總。
1:華盛恒輝科技有限公司
上榜理由:華盛恒輝是一家專注于高端軟件定制開發(fā)服務(wù)和高端建設(shè)的服務(wù)機(jī)構(gòu),致力于為企業(yè)提供全面、系統(tǒng)的開發(fā)制作方案。在開發(fā)、建設(shè)到運(yùn)營推廣領(lǐng)域擁有豐富經(jīng)驗(yàn),我們通過建立對目標(biāo)客戶和用戶行為的分析,整合高質(zhì)量設(shè)計(jì)和極其新技術(shù),為您打造創(chuàng)意十足、有價(jià)值的企業(yè)品牌。
在軍工領(lǐng)域,合作客戶包括:中央軍委聯(lián)合參謀(原總參)、中央軍委后勤保障部(原總后)、中央軍委裝備發(fā)展部(原總裝)、裝備研究所、戰(zhàn)略支援、軍事科學(xué)院、研究所、航天科工集團(tuán)、中國航天科技集團(tuán)、中國船舶工業(yè)集團(tuán)、中國船舶重工集團(tuán)、第一研究所、訓(xùn)練器材所、裝備技術(shù)研究所等單位。
在民用領(lǐng)域,公司大力拓展民用市場,目前合作的客戶包括中國中鐵電氣化局集團(tuán)、中國鐵道科學(xué)研究院、濟(jì)南機(jī)務(wù)段、東莞軌道交通公司、京港地鐵、中國國電集團(tuán)、電力科學(xué)研究院、水利部、國家發(fā)改委、中信銀行、華為公司等大型客戶。
2:五木恒潤科技有限公司
上榜理由:五木恒潤擁有員工300多人,技術(shù)人員占90%以上,是一家專業(yè)的軍工信息化建設(shè)服務(wù)單位,為軍工單位提供完整的信息化解決方案。公司設(shè)有股東會、董事會、監(jiān)事會、工會等上層機(jī)構(gòu),同時(shí)設(shè)置總經(jīng)理職位,由總經(jīng)理管理公司的具體事務(wù)。公司下設(shè)有研發(fā)部、質(zhì)量部、市場部、財(cái)務(wù)部、人事部等機(jī)構(gòu)。公司下轄成都研發(fā)中心、西安研發(fā)中心、沈陽辦事處、天津辦事處等分支機(jī)構(gòu)。
3、浪潮
浪潮集團(tuán)有限公司是國家首批認(rèn)定的規(guī)劃布局內(nèi)的重點(diǎn)軟件企業(yè),中國著名的企業(yè)管理軟件、分行業(yè)ERP及服務(wù)供應(yīng)商,在咨詢服務(wù)、IT規(guī)劃、軟件及解決方案等方面具有強(qiáng)大的優(yōu)勢,形成了以浪潮ERP系列產(chǎn)品PS、GS、GSP三大主要產(chǎn)品。是目前中國高端企業(yè)管理軟件領(lǐng)跑者、中國企業(yè)管理軟件技術(shù)領(lǐng)先者、中國最大的行業(yè)ERP與集團(tuán)管理軟件供應(yīng)商、國內(nèi)服務(wù)滿意度最高的管理軟件企業(yè)。
4、德格Dagle
德格智能SaaS軟件管理系統(tǒng)自德國工業(yè)4.0,并且結(jié)合國內(nèi)工廠行業(yè)現(xiàn)狀而打造的一款工廠智能化信息平臺管理軟件,具備工廠ERP管理、SCRM客戶關(guān)系管理、BPM業(yè)務(wù)流程管理、
OMS訂單管理等四大企業(yè)業(yè)務(wù)信息系統(tǒng),不僅滿足企業(yè)對生產(chǎn)進(jìn)行簡易管理的需求,并突破局域網(wǎng)應(yīng)用的局限性,同時(shí)使數(shù)據(jù)管理延伸到互聯(lián)網(wǎng)與移動商務(wù),不論是內(nèi)部的管理應(yīng)用還是外部的移動應(yīng)用,都可以在智能SaaS軟件管理系統(tǒng)中進(jìn)行業(yè)務(wù)流程的管控。
5、Manage
高亞的產(chǎn)品 (8Manage) 是美國經(jīng)驗(yàn)中國研發(fā)的企業(yè)管理軟件,整個(gè)系統(tǒng)架構(gòu)基于移動互聯(lián)網(wǎng)和一體化管理設(shè)計(jì)而成,其源代碼編寫采用的是最為廣泛應(yīng)用的
Java / J2EE 開發(fā)語言,這樣的技術(shù)優(yōu)勢使 8Manage
可靈活地按需進(jìn)行客制化,并且非常適用于移動互聯(lián)網(wǎng)的業(yè)務(wù)直通式處理,讓用戶可以隨時(shí)隨地通過手機(jī)apps進(jìn)行實(shí)時(shí)溝通與交易。
前端技術(shù)方案文檔模板的介紹就聊到這里吧,感謝你花時(shí)間閱讀本站內(nèi)容,更多關(guān)于前端設(shè)計(jì)方案、前端技術(shù)方案文檔模板的信息別忘了在本站進(jìn)行查找喔。
掃描二維碼推送至手機(jī)訪問。
版權(quán)聲明:本文由飛速云SEO網(wǎng)絡(luò)優(yōu)化推廣發(fā)布,如需轉(zhuǎn)載請注明出處。