基於阿里egg框架搭建博客(1)——開發準備

相關文章

基於阿里egg框架搭建博客(1)——開發準備
基於阿里egg框架搭建博客(2)——Hello World
基於阿里egg框架搭建博客(3)——註冊與登陸
基於阿里egg框架搭建博客(4)——權限控制
基於阿里egg框架搭建博客(5)——置頂導航條
基於阿里egg框架搭建博客(6)——瀏覽、發表文章
基於阿里egg框架搭建博客(7)——編輯文章css

git

https://github.com/ZzzSimon/e...
喜歡就點個贊吧!html

什麼是egg.js

簡單來說就是一個基於nodejs與koa的WEB框架。node

官方介紹: https://eggjs.org/zh-cn/intro...

環境準備

  1. 安裝nodejs環境,下載地址:https://nodejs.org/en/download/
  2. 安裝腳手架,在此基礎上開發,具體執行如下命令:
$ npm i egg-init -g
$ egg-init egg-blog --type=simple
$ cd egg-blog
$ npm i

非腳手架(初學者推薦)

若是是初學者,建議本身建立全部的目錄,以熟悉Egg官方所約定的規則。git

官方demo: https://eggjs.org/zh-cn/intro...

腳手架

Egg 奉行『 約定優於配置』,按照 一套統一的約定進行應用開發,團隊內部採用這種方式能夠減小開發人員的學習成本,開發人員再也不是『釘子』,能夠流動起來。沒有約定的團隊,溝通成本是很是高的,好比有人會按目錄分棧而其餘人按目錄分功能,開發者認知不一致很容易犯錯。

如Egg官方所言,腳手架是對應用目錄作了一個規範的示範,咱們在此基礎上開發能省下很多功夫。
執行完上述命令以後,咱們能夠看到以下的目錄結構:github

egg-project
├── package.json
├── app.js (可選)
├── agent.js (可選)
├── app
|   ├── router.js
│   ├── controller
│   |   └── home.js
│   ├── service (可選)
│   |   └── user.js
│   ├── middleware (可選)
│   |   └── response_time.js
│   ├── schedule (可選)
│   |   └── my_task.js
│   ├── public (可選)
│   |   └── reset.css
│   ├── view (可選)
│   |   └── home.tpl
│   └── extend (可選)
│       ├── helper.js (可選)
│       ├── request.js (可選)
│       ├── response.js (可選)
│       ├── context.js (可選)
│       ├── application.js (可選)
│       └── agent.js (可選)
├── config
|   ├── plugin.js
|   ├── config.default.js
│   ├── config.prod.js
|   ├── config.test.js (可選)
|   ├── config.local.js (可選)
|   └── config.unittest.js (可選)
└── test
    ├── middleware
    |   └── response_time.test.js
    └── controller
        └── home.test.js

如上,由框架約定的目錄:npm

  • app/router.js 用於配置 URL 路由規則,具體參見 Router
  • app/controller/** 用於解析用戶的輸入,處理後返回相應的結果,具體參見 Controller
  • app/service/** 用於編寫業務邏輯層,可選,建議使用,具體參見 Service
  • app/middleware/** 用於編寫中間件,可選,具體參見 Middleware
  • app/public/** 用於放置靜態資源,可選,具體參見內置插件 egg-static
  • app/extend/** 用於框架的擴展,可選,具體參見框架擴展
  • config/config.{env}.js 用於編寫配置文件,具體參見配置
  • config/plugin.js 用於配置須要加載的插件,具體參見插件
  • test/** 用於單元測試,具體參見單元測試
  • app.jsagent.js 用於自定義啓動時的初始化工做,可選,具體參見啓動自定義。關於agent.js的做用參見Agent機制

由內置插件約定的目錄:json

  • app/public/** 用於放置靜態資源,可選,具體參見內置插件 egg-static
  • app/schedule/** 用於定時任務,可選,具體參見定時任務

若需自定義本身的目錄規範,參見 Loader APIsegmentfault

  • app/view/** 用於放置模板文件,可選,由模板插件約定,具體參見模板渲染
  • app/model/** 用於放置領域模型,可選,由領域類相關插件約定,如 egg-sequelize

結尾

若是看完以爲有用,請給做者一個喜歡吧!謝謝啦!app

相關文章
相關標籤/搜索