/oxc-blog-server

Primary LanguageTypeScriptMIT LicenseMIT

介绍

  • 前后端分离项目,前端地址
  • 文章功能支持 markdown 方式编写及展示,并且支持简书式的边写边看,支持图片一键黏贴直传七牛 cdn
  • 该博客虽然作为个人博客并且为单人编写,但是目的在于实践一个多人工作的环境,所以也含有多个团队合作时候使用的库

地址

搭建过程系列文章

  1. 项目及其技术栈介绍
  2. 前端: 项目初始化
  3. 前端: 使用 Sass 和 Antd
  4. 前端: 开发体验优化
  5. 前端: 搭建路由和状态管理
  6. 前端: 支持 Axios
  7. 前端: 打包与环境变量设置
  8. 前端: 团队代码规范
  9. 后端: 项目初始化和使用 Koa 相关
  10. 后端: 使用 TypeORM 和 MySQL
  11. 部署: 使用 nginx 部署前端项目
  12. 部署: 后端部署
  13. 部署: 使用 jenkins 自动化部署

技术栈

  • 前端:

    • TypeScript
    • React v16.9.11: hook,状态管理使用 useReducer + context
    • Axios
    • WebPack: 自定义的 WebPack 规则及打包规则
    • Marked + hightlight.js + CodeMirror + react-codemirror2
    • Sass: css-module
  • 后端:

    • TypeScript
    • Koa2 + koa-router + koa-bodyparser
    • TypeORM
    • MySQL
  • 代码规范:

    • Commitlint
    • ESlint
    • Prettier
    • Stylelint

预览

项目结构

前端

oxc-blog
├─ .eslintrc.js           // eslint配置
├─ .prettierrc.js         // prettierrc配置
├─ .stylelintrc.js        // stylelint配置
├─ build                  // webpack相关
├─ commitlint.config.js   // commitlint配置
├─ deploy                 // 部署后直传七牛脚本
├─ src
│    ├─ assets            // 静态资源
│    ├─ constants         // 常量
│    ├─ containers        // 内涵shared和views两个文件夹,用于存放页面和组件
│    ├─ index.tsx         // 入口文件
│    ├─ services          // axios和相关api封装存放
│    ├─ store             // 状态管理,内含ts定义
│    ├─ styles            // 常用sass样式存放
│    ├─ types             // 全局接口ts定义
│    └─ utils             // 常用工具
└─ tsconfig.json

后端

oxc-blog-server
├─ .eslintrc.js        // eslint配置
├─ nodemon.json        // nodemon配置
├─ ormconfig.js        // typeorm数据库配置
├─ src
│    ├─ controller     // 业务逻辑
│    ├─ entity         // 数据库模型
│    ├─ index.ts       // 入口
│    ├─ middlewares    // 常用中间件
│    ├─ routes         // 路由表
│    ├─ types          // 针对数据库模型编写的类型
│    └─ utils          // 常用工具
└─ tsconfig.json

数据结构图

协议

MIT Licence