91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

發布時間:2021-10-20 16:28:15 來源:億速云 閱讀:134 作者:iii 欄目:web開發

這篇文章主要講解了“如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS”吧!

技術架構和實現方案

為了降低大家的使用和部署成本, 我們采用了如下技術實現:

  • 服務層: koa2 + nodejs + jsonSchema(當然其中還使用了很多nodejs中間件)

  • 前臺頁面: pug(結合nodejs實現前后端同構, 且天然的SSR)

  • 后臺管理: umi3.0 + react + antd + axios + typescript(當然還用了很多前端插件, 比如富文本,  md編輯器)

  • 系統/服務器相關: linux / pm2 / nginx

基本架構模式如下圖所示:

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

系統頁面架構圖:

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

功能分析

接下來筆者就來介紹 simpleCMS 的功能點. 我們先來分析一下后臺管理系統.

后臺管理系統功能分析

后臺管理系統是動態博客系統必備的模塊, 它能很方便的管理我們的網站數據. 這里筆者先來帶大家看一下后臺管理系統的基本模塊:

  • 登錄頁面

  • 數據大盤

  • 內容管理

  • 頁面配置

  • 廣告配置

  • 用戶信息管理

  • 多語言支持

以上是 cms 管理系統必備的模塊, 這里我們基本上采用react hooks 來寫, 具體頁面如下:

1 登錄頁面

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

2 數據大盤

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

3 文章管理

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

4 內容編輯

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

5 多語言支持

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

其他頁面就不一一展示了, 感興趣的朋友可以體驗一下. 主要技術采用 umi + antd + react + typescript 實現, 感興趣可以在  github 上參考學習.

前臺基本功能分析

前臺主要是我們的博客網站, 這里采用 pug 這個模版引擎來實現, 交互功能使用大家最熟悉的jquery.前臺基本模塊有:

  • 博客首頁

  • 文章列表頁

  • 文章詳情頁

對應的交互功能有點贊, 評論, 文章搜索功能等, 基本頁面如下:

1 首頁

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

2 列表頁

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

3 詳情頁

 如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

4 評論和點贊

 如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

由于pug模版引擎適合做一些展示型的網站, 所以非常適合用在cms系統中, 我們也可以使用ejs等模版引擎.

技術實現細節

由于整個cms 系統是一個完整的技術閉環, 數據流轉都是相關的, 這里筆者主要總結一下實現一個cms的技術細節.

  • 數據統計功能實現 —— 采用nodejs定時任務(node-schedule)

  • 富文本和md編輯器實現

  • 后臺多語言實現方案

  • 內容管理流程設計

  • pug 模版和數據交互

  • jsonSchema 數據結構設計

  • 手寫簡單加密解密算法

  • 跨域解決方案以及用戶權限設計

  • pm2管理node進程以及做負載均衡

  • 多進程場景下的并發鎖設計

數據統計功能實現

數據統計主要是統計網站的pv, 單篇文章閱讀量和點贊量, 為了更好的進行分析我們需要對單日的數據進行統計和存庫,  具體實現就是利用定時任務在一天結束前進行數據的統計, 這里我們用 node-schedule來實現, 具體使用方式筆者也在之前的文章中做了介紹,  感興趣可以參考一下.

如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS

基本使用如下:

let schedule = require('node-schedule');  let testJob = schedule.scheduleJob('42 * * * *', function(){   console.log('將在未來的每個時刻的42分時執行此代碼, 比如22:42, 23:42'); });

富文本和md編輯器方案實現

這里我們用的富文本組件是braft, 功能和可擴展性基本滿足業務需求, md編輯器是程序員寫博客的基本方式, 這里主要采用了for-editor,  其次就是對其進行了二次封裝來實現支持剪切板功能.

國際化方案

多語言主要使用的react-intl, 由于umi 對其有很好的集成, 所以說我們只需要搭建基本的多語言規則即可.  比如在項目目錄里建立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系統, 助力每個人都能擁有自己的網站博客。',   CopyrightText: 'SimpleCMS 研發團隊' }

感謝各位的閱讀,以上就是“如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS”的內容了,經過本文的學習后,相信大家對如何從零打造一款輕量且天然支持SSR的CMS系統-SimpleCMS這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鹿泉市| 巫山县| 雅安市| 永嘉县| 呈贡县| 广安市| 新龙县| 慈利县| 吉安县| 金平| 大足县| 娄底市| 德清县| 宝应县| 军事| 临澧县| 边坝县| 兴仁县| 宝山区| 军事| 荥经县| 肥乡县| 泌阳县| 达州市| 泸水县| 蒙阴县| 甘泉县| 灵石县| 九龙城区| 九寨沟县| 获嘉县| 凌海市| 宁晋县| 延川县| 江陵县| 盘锦市| 瓦房店市| 富蕴县| 渭南市| 肥东县| 静海县|