国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

構建一個后臺管理系統要考慮哪些內容

社區管理員 / 817人閱讀

一、前言

昨天一個朋友問:我的工作只有vue、react,了解其他的好像沒有太大作用。其實不然,前端要考慮的內容其實很多,不光是完成業務代碼。

我司的一個控制臺前端維護人數在20+,如果每個人都在一個項目中開發,那么每天就等著構建了,不僅容易出錯,而且浪費時間,這對于線上項目是不可容忍的。

前端項目有大有小,這里假設我們面對的是一個相對復雜的中臺系統,那么要考慮的東西是很多的。下面我列舉了大部分,如果有缺失歡迎小伙伴補充。

下面列舉的內容包含了必須的模塊,比如框架選型,接口調用,公共組件

有些是可選的模塊,比如各種規范約束,單元測試,多語言支持、模擬數據

還有一些是隨著系統的變大需要增加的,比如版本管理、灰度系統、自動構建部署、頁面監控,質量測試,數據監控等。

有一些是多人合作,提升效率的,比如前端CICD部署、微前端服務器

二、內容總覽

- 1、基礎設施     - 1.1、文檔規范         - 1.1.1、接口文檔         - 1.1.2、開發文檔     - 1.2、代碼規范         - 1.2.1、Gitlab、git分支提交規范         - 1.2.2、tsconfig  (ts配置)         - 1.2.3、eslint 代碼質量         - 1.2.4、pritter代碼格式化         - 1.2.5、css規范             - 1.2.5.1、重置瀏覽器樣式             - 1.2.5.2、兼容內容         - 1.2.6、項目目錄規范         - 1.2.7、版本管理規范         - 1.2.8、接口規范         - 1.2.9、工具類函數和變量規范         - 1.2.10、注釋規范         - 1.2.11、項目環境配置(開發、生產、測試)         - 1.2.12、皮膚主題切換、語言切換     - 1.3、常用技術         - webpack         - mock         - 狀態管理     - 1.4、ui組件庫     - 1.5、cli腳手架 - 2、開發階段     - 2.1、技術選型         - 2.1.1、微前端框架         - 2.1.2、js庫選型         - 2.1.3、路由、導航規范     - 2.2、主要模塊         - 2.2.1、權限系統         - 2.2.2、公用組件管理         - 2.2.3、頁面框架     - 2.3、代碼質量         - 2.3.1、單元測試         - 2.3.2、代碼質量檢測         - 2.3.3、關鍵頁面性能分析     - 2.4、文件、圖片懶加載     - 2.5、其他         - 2.5.1、反向代理配置         - 2.5.2、模擬數據         - 2.5.3、引入路徑配置 - 3、部署階段     - 3.1、項目環境區分     - 3.2、自動化部署         - 3.3.1、shell腳本         - 3.3.2、CI/CD         - 3.3.3、代理、緩存配置、代碼壓縮     - 3.1、灰度系統     - 3.4、回退方案     - 3.5、容災方案     - 3.6、CDN - 4、監控階段     - 4.1、前端js報錯監控     - 4.2、頁面訪問統計系統     - 4.3、特殊頁面埋點 復制代碼

三、基礎設施

1.1、文檔規范

那句話咋說來著:研發最討厭的就是寫文檔,最喜歡的就是別人寫文檔

對于前后端分離開發來說,文檔是很重要的。

沒有文檔,大大增加了溝通成本,而且后期問題確認,維護都會很困難。

但后端又忙的沒有時間寫文檔,所以更多的時候最少可以通過自動化手段生成文檔,比如我這邊開發Golang服務、Node服務會使用Swagger生成文檔,對于工期緊張的項目,當然也可以通過Postman分享給前端,這樣對于雙方都可以減輕負擔。

開發文檔,可以幫助開發理清思路,記錄開發過程中困難,當然你的項目天天十萬火急,就當我沒說。

1.2、代碼管理

代碼管理,對公司而言,一般直接使用Gitlab就行了,搭建成本也很低,權限控制、自動發布等很完善了,當然一定要備份。

通過Gitlab,設置管理員權限,其他的角色可以分配可讀,可合并,可發布等權限。

為了代碼的干凈整潔,更好的維護,代碼格式化,代碼質量,初始化樣式、目錄規范、接口規范、注釋規范、工具類函數規范等都是要提前確定好的,防止后面越寫越亂。

當然項目更新頻繁,還要考慮版本管理

項目有國外的用戶,需要配置語言切換。

換膚效果也是很多網站會需要的。

一個項目一般由一個人或多人開發,涉及到不同的功能,不同的人員,那么Git就是你必須要考慮的。涉及到多人管理,還會存在分支管理的問題,如果不同的人隨便搞,容易造成代碼混亂,所以在開發項目之前要制定Git代碼分支管理規范。

Git分支提交規范,如何區分提交內容,是bug、新功能、優化還是其他。如果定義好,對于之后的歷史查找會方便很多

1.3、其他

前端項目mock數據引入,方便前端調試和獨立開發。

如果公司的項目規模比較大,可能需要自建UI組件庫,配置CLI腳手架,去方便組員拉取代碼

很多人不寫代碼注釋,我也不喜歡寫,但注釋也是代碼的一部分,沒有好的注釋,一些業務要不了多久再看,就會一頭霧水,所以注釋能寫盡量寫,磨刀不誤砍柴工。

// 原則上空一格,單行注釋

/**/ 如果多行注釋可以使用這種方法,每個文件開頭可以使用的注釋格式有:

文件開頭一般寫上:

作者: 日期: 描述: 復制代碼

上面是一些建議的規范,當然優秀的程序員要,可以直接使用插件,生成注釋,然后使用eslint去規范注釋的格式,這樣就可以保證項目中注釋的規范。

缺點是:增加了開發的成本,拖慢項目速度。如果你天天趕工期,還是把eslint禁了吧,寫完早點回家看看其他公司的機會。

四、開發階段

2.1、技術選型

現在我開發使用比較多的是,前后端分離的單頁應用,這里我們就以這種后臺為引,默認前后端分離。

考慮技術選型,其實Vue和React已經幾乎能滿足所有的公司了,就算需要高度SEO,也有很多解決方案。

微前端,是必須要考慮的一個環節,如果項目劃分成了很多產品,每個產品都有對應的需求,想要所有的項目匯總在一個平臺,那么微前端絕對是不二的選擇,實現方案也比較多,可以選擇最合適的。

路由、導航都建議提取配置文件,可以讓項目更好的管理。

一個好的目錄結構,應該是職責分明的。每個目錄做對應的事情,公用組件文件夾,工具函數文件、頁面路由文件、狀態管理文件等。

2.2、后臺的常見模塊

1、大多數后臺都需要權限管理,然后根據每個員工的角色不同,看到不同的內容,那么就要求前端做好權限管理模塊的規劃,提取公用配置,進行多帶帶管理

2、公共組件,很多需求都是可以復用的,提高組件的復用性,可以減少代碼量,提高系統性能。

2.3、代碼質量

本是同根生,相煎何太急。需求實現就行了,干啥這樣? 但對于生產環境的項目來說,少一個bug就多一個客戶,所以為了保障線上的穩定,這里有很多方案去解決。

上線前的單元測試,部署代碼分析系統來分析頁面的代碼質量。對于關鍵的頁面還要進行針對的分析,查看加載速度,訪問數據等等

五、部署階段

3.1、打包部署

項目部署,可以很簡單,也可以很復雜,具體取決于自身需求。

如果簡單的可以通過shell腳本處理,復雜一點的可以通過CICD+K8S構建。

3.2、打包不同的環境

我們的項目基本不會只部署生產環境,常常需要部署測試環境,那么我們常見的做法是通過配置環境變量來控制打包。

3.3、灰度系統

項目上線前要考慮,出現問題怎么及時挽救,這里我們就要考慮,要怎么實現灰度方案,在全面部署前,先灰度一部分用戶,就像手機軟件常常要求你體驗搶鮮版,確保基本沒問題,在正式部署。

3.4、版本回退

一個項目在發布出現問題后,必須要有回退的能力。這樣當遇到問題時,可以及時的進行代碼的回滾操作,保證線上穩定。

3.5、容災

自然災害誰也料不到,如果單點部署我們的業務,一旦云服務商一個機房出現問題或虛機宕機,必然影響到業務,所以要考慮負載均衡,多節點部署。

3.6、CDN

大訪問量的網站,如果廣州的客戶請求部署在北京機房的服務,那么打開速度必要會慢,在廣州買臺服務器卻沒有必要,這時候選擇CDN,通過一個個節點,減輕服務器壓力,讓用戶打開速度更快。

六、監控階段

想像一下,如果你打開一個網站,前端報錯,這時候頁面卡死,作為開發其實是看不到的,那么就無法解決這個問題,可能用戶就直接關了這個頁面,不再訪問了。這樣肯定是不行的,我們可以通過監控系統,去收集這些錯誤,及時解決這些bug,比如開源軟件sentry

用戶是通過什么渠道進入你的頁面的,你的頁面每天的訪問量是多少?我們可以通過統計系統分析日志請求,來匯總這些信息,常見的有百度統計。

對于一些重要的頁面,也需要增加標記,記錄訪問用戶,一旦惡意請求,可以及時屏蔽,比如goaccess分析nginx日志。

七、最后

當然這其中很多都是一些規范問題,對于小項目來說,考慮的不多; 對于大項目來說,很多內容也都是只需要一次配置,也有一些方案是根據項目發展來配置的,比如灰度系統的實現方案。

以上是我現在可以考慮到的方面,不足的方面希望各位可以補充下。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/127956.html

相關文章

  • 小程序上云,有點猛

    摘要:另外小程序云應用有一套高可用架構,提供監控預警能力。自主可控小程序云應用提供服務器,開發者可以擁有登錄或重啟,也可以修改密碼。也就是說,服務器是由小程序云應用提供,但使用權歸開發者。  前不久有一個朋友問我,到底是做什么端的小程序比較好?   我只問了一句,你的產品里是否涉及錢和服務,如果涉及這兩者,建議你選擇支付寶小程序。你可以通過其他小程序玩裂變,但如果你想做服務和商業,一定要考慮支付寶...

    jsdt 評論0 收藏0
  • 前端架構涉及到哪些范圍?

    摘要:前后端都要關注注入攻擊跨站腳本攻擊跨站請求偽造開放重定向這些安全性問題。前端也需要構建自動化測試,包括獨立單元測試和端到端測試自動化,當然還有人工測試。 總體指導思想是前后端分離,后端同事提供線上API數據查詢接口或websocket接口,前端同事負責處理獲取到的數據、編寫展示的頁面、實現用戶交互;前后端都要考慮web開發的安全性問題,表單提交到數據庫前對用戶的輸入進行轉義、登錄避免明...

    dmlllll 評論0 收藏0
  • 前端架構涉及到哪些范圍?

    摘要:前后端都要關注注入攻擊跨站腳本攻擊跨站請求偽造開放重定向這些安全性問題。前端也需要構建自動化測試,包括獨立單元測試和端到端測試自動化,當然還有人工測試。 總體指導思想是前后端分離,后端同事提供線上API數據查詢接口或websocket接口,前端同事負責處理獲取到的數據、編寫展示的頁面、實現用戶交互;前后端都要考慮web開發的安全性問題,表單提交到數據庫前對用戶的輸入進行轉義、登錄避免明...

    kk_miles 評論0 收藏0
  • 了解Chrome擴展程序開發

    摘要:了解擴展程序開發本文大量借鑒圖靈電子書擴展及應用開發首發版首先,我嘗試來用簡單幾句話描述一下擴展程序擴展主要用于對瀏覽器功能的增強,它強調與瀏覽器相結合。提供了接口,允許擴展對用戶的歷史進行管理。 了解Chrome擴展程序開發 本文大量借鑒圖靈電子書-Chrome擴展及應用開發(首發版) 首先,我嘗試來用簡單幾句話描述一下Chrome擴展程序: Chrome擴展主要用于對瀏覽器功能的增...

    lemanli 評論0 收藏0

發表評論

0條評論

社區管理員

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<