這篇文章主要講解了“如何從零打造一款輕量且天然支持SSR的CMS系統(tǒng)-SimpleCMS”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何從零打造一款輕量且天然支持SSR的CMS系統(tǒng)-SimpleCMS”吧!
成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、頭屯河網(wǎng)絡(luò)推廣、微信平臺小程序開發(fā)、頭屯河網(wǎng)絡(luò)營銷、頭屯河企業(yè)策劃、頭屯河品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學生創(chuàng)業(yè)者提供頭屯河建站搭建服務(wù),24小時服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com
技術(shù)架構(gòu)和實現(xiàn)方案
為了降低大家的使用和部署成本, 我們采用了如下技術(shù)實現(xiàn):
服務(wù)層: koa2 + nodejs + jsonSchema(當然其中還使用了很多nodejs中間件)
前臺頁面: pug(結(jié)合nodejs實現(xiàn)前后端同構(gòu), 且天然的SSR)
后臺管理: umi3.0 + react + antd + axios + typescript(當然還用了很多前端插件, 比如富文本, md編輯器)
系統(tǒng)/服務(wù)器相關(guān): linux / pm2 / nginx
基本架構(gòu)模式如下圖所示:
系統(tǒng)頁面架構(gòu)圖:
功能分析
接下來筆者就來介紹 simpleCMS 的功能點. 我們先來分析一下后臺管理系統(tǒng).
后臺管理系統(tǒng)功能分析
后臺管理系統(tǒng)是動態(tài)博客系統(tǒng)必備的模塊, 它能很方便的管理我們的網(wǎng)站數(shù)據(jù). 這里筆者先來帶大家看一下后臺管理系統(tǒng)的基本模塊:
登錄頁面
數(shù)據(jù)大盤
內(nèi)容管理
頁面配置
廣告配置
用戶信息管理
多語言支持
以上是 cms 管理系統(tǒng)必備的模塊, 這里我們基本上采用react hooks 來寫, 具體頁面如下:
1 登錄頁面
2 數(shù)據(jù)大盤
3 文章管理
4 內(nèi)容編輯
5 多語言支持
其他頁面就不一一展示了, 感興趣的朋友可以體驗一下. 主要技術(shù)采用 umi + antd + react + typescript 實現(xiàn), 感興趣可以在 github 上參考學習.
前臺基本功能分析
前臺主要是我們的博客網(wǎng)站, 這里采用 pug 這個模版引擎來實現(xiàn), 交互功能使用大家最熟悉的jquery.前臺基本模塊有:
博客首頁
文章列表頁
文章詳情頁
對應(yīng)的交互功能有點贊, 評論, 文章搜索功能等, 基本頁面如下:
1 首頁
2 列表頁
3 詳情頁
4 評論和點贊
由于pug模版引擎適合做一些展示型的網(wǎng)站, 所以非常適合用在cms系統(tǒng)中, 我們也可以使用ejs等模版引擎.
技術(shù)實現(xiàn)細節(jié)
由于整個cms 系統(tǒng)是一個完整的技術(shù)閉環(huán), 數(shù)據(jù)流轉(zhuǎn)都是相關(guān)的, 這里筆者主要總結(jié)一下實現(xiàn)一個cms的技術(shù)細節(jié).
數(shù)據(jù)統(tǒng)計功能實現(xiàn) —— 采用nodejs定時任務(wù)(node-schedule)
富文本和md編輯器實現(xiàn)
后臺多語言實現(xiàn)方案
內(nèi)容管理流程設(shè)計
pug 模版和數(shù)據(jù)交互
jsonSchema 數(shù)據(jù)結(jié)構(gòu)設(shè)計
手寫簡單加密解密算法
跨域解決方案以及用戶權(quán)限設(shè)計
pm2管理node進程以及做負載均衡
多進程場景下的并發(fā)鎖設(shè)計
數(shù)據(jù)統(tǒng)計功能實現(xiàn)
數(shù)據(jù)統(tǒng)計主要是統(tǒng)計網(wǎng)站的pv, 單篇文章閱讀量和點贊量, 為了更好的進行分析我們需要對單日的數(shù)據(jù)進行統(tǒng)計和存庫, 具體實現(xiàn)就是利用定時任務(wù)在一天結(jié)束前進行數(shù)據(jù)的統(tǒng)計, 這里我們用 node-schedule來實現(xiàn), 具體使用方式筆者也在之前的文章中做了介紹, 感興趣可以參考一下.
基本使用如下:
let schedule = require('node-schedule'); let testJob = schedule.scheduleJob('42 * * * *', function(){ console.log('將在未來的每個時刻的42分時執(zhí)行此代碼, 比如22:42, 23:42'); });
富文本和md編輯器方案實現(xiàn)
這里我們用的富文本組件是braft, 功能和可擴展性基本滿足業(yè)務(wù)需求, md編輯器是程序員寫博客的基本方式, 這里主要采用了for-editor, 其次就是對其進行了二次封裝來實現(xiàn)支持剪切板功能.
國際化方案
多語言主要使用的react-intl, 由于umi 對其有很好的集成, 所以說我們只需要搭建基本的多語言規(guī)則即可. 比如在項目目錄里建立locales文件夾, 然后存放zh(中文)/en(英文)文件即可, 基本的代碼如下:
// locales/en/user export default { simpleCMS_DESC: 'Easy to use CMS system, help everyone to have their own website blog.', CopyrightText: 'SimpleCMS r&d team', } // locales/zh/user export default { simpleCMS_DESC: '簡單易用的cms系統(tǒng), 助力每個人都能擁有自己的網(wǎng)站博客。', CopyrightText: 'SimpleCMS 研發(fā)團隊' }
感謝各位的閱讀,以上就是“如何從零打造一款輕量且天然支持SSR的CMS系統(tǒng)-SimpleCMS”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對如何從零打造一款輕量且天然支持SSR的CMS系統(tǒng)-SimpleCMS這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!