摘要:是什么是一款頂級(jí)全棧開發(fā)框架。漸進(jìn)式開發(fā)由于模塊的高度內(nèi)聚,可以將業(yè)務(wù)以模塊的形式沉淀,在多個(gè)項(xiàng)目中重復(fù)使用,既可貢獻(xiàn)到開源社區(qū),也可部署到公司內(nèi)部私有倉庫。模塊發(fā)布當(dāng)項(xiàng)目中的模塊代碼穩(wěn)定后,可以將模塊公開發(fā)布,貢獻(xiàn)到開源社區(qū)。
EggBorn.js是什么
EggBorn.js是一款頂級(jí)Javascript全棧開發(fā)框架。
EggBorn.js是采用Javascript進(jìn)行全棧開發(fā)的最佳實(shí)踐。
EggBorn.js不重復(fù)造輪子,而是采用業(yè)界最新的開源技術(shù),進(jìn)行全棧開發(fā)的最佳組合。
EggBorn.js前端采用Vue.js + Framework7 / Vue Router + Webpack,后端采用Koa.js + Egg.js,數(shù)據(jù)庫采用mysql。
EggBorn.js時(shí)刻跟蹤開源技術(shù)的最新成果,并持續(xù)優(yōu)化,使整個(gè)框架時(shí)刻保持最佳狀態(tài)。
Javascript技術(shù)的蓬勃發(fā)展,為前后端開發(fā)帶來了更順暢的體驗(yàn),顯著提升了開發(fā)效率。但仍有網(wǎng)友質(zhì)疑Javascript能否勝任大型Web應(yīng)用的開發(fā)。大型Web應(yīng)用的特點(diǎn)是隨著業(yè)務(wù)的增長,需要開發(fā)大量的頁面組件。面對(duì)這種場景,一般有兩種解決方案:
1 采用單頁面的構(gòu)建方式,缺點(diǎn)是產(chǎn)生的部署包很大。
2 采用頁面異步加載方式,缺點(diǎn)是頁面過于零散,需要頻繁與后端交互。
EggBorn.js實(shí)現(xiàn)了第三種解決方案:
EggBorn.js的技術(shù)特點(diǎn)3 頁面組件按業(yè)務(wù)需求歸類,進(jìn)行模塊化,并且實(shí)現(xiàn)了模塊的異步加載機(jī)制,從而彌合了前兩種解決方案的缺點(diǎn),完美滿足大型Web應(yīng)用業(yè)務(wù)持續(xù)增長的需求。
業(yè)務(wù)模塊化:頁面組件按模塊組織
加載方式靈活:模塊既可異步加載,也可同步加載
模塊高度內(nèi)聚:模塊包括前端頁面組件和后端業(yè)務(wù)邏輯
參數(shù)配置靈活:模塊中的前后端可以多帶帶進(jìn)行參數(shù)配置
國際化:模塊中的前后端均支持獨(dú)立的國際化
模塊隔離:模塊的頁面、數(shù)據(jù)、邏輯、路由、配置等元素均進(jìn)行了命名空間隔離處理,避免模塊之間的變量污染與沖突
超級(jí)易用的事務(wù)處理:只需在路由記錄上配置一個(gè)參數(shù),即可完美實(shí)現(xiàn)數(shù)據(jù)庫的事務(wù)處理。
漸進(jìn)式開發(fā):由于模塊的高度內(nèi)聚,可以將業(yè)務(wù)以模塊的形式沉淀,在多個(gè)項(xiàng)目中重復(fù)使用,既可貢獻(xiàn)到npm開源社區(qū),也可部署到公司內(nèi)部私有npm倉庫。
快速上手 安裝EggBorn.js腳手架有了EggBorn.js,從此可復(fù)用的不僅僅是組件,還有業(yè)務(wù)模塊。
$ npm install -g egg-born新建項(xiàng)目
$ egg-born project_name $ cd project_name $ npm install
配置mysql連接參數(shù)EggBorn.js目前提供了2個(gè)項(xiàng)目腳手架,分別是
front-backend-mysql -- 前后端全棧項(xiàng)目模板
front -- 前端項(xiàng)目模板,后端可采用其他方案
如果采用了front-backend-mysql模板,請(qǐng)配置mysql連接參數(shù)(空數(shù)據(jù)庫即可)
編輯src/backend/config/config.default.js文件
// mysql config.mysql = { clients: { // donot change the name __ebdb: { host: "127.0.0.1", port: "3306", user: "travis", password: "", database: "egg-born", }, }, };運(yùn)行項(xiàng)目
啟動(dòng)后端服務(wù)
$ npm run dev:backend
啟動(dòng)前端服務(wù)
$ npm run dev:frontEggBorn.js架構(gòu)圖 系統(tǒng)架構(gòu) 項(xiàng)目文件結(jié)構(gòu) 模塊文件結(jié)構(gòu) 模塊開發(fā) 命名約定
為了不斷沉淀業(yè)務(wù)模塊,達(dá)到高度可復(fù)用的效果,所有模塊的命名空間必須充分隔離,避免相互污染與沖突,故采用如下命名方式:
egg-born-module-{providerId}-{moduleName}
如模塊egg-born-module-a-version,各環(huán)節(jié)命名信息如下:
加載機(jī)制providerId: a
moduleName: version
fullName: egg-born-module-a-version
relativeName: a-version
前端頁面路由地址: /a/version/{page}
后端API路由地址:/a/version/{controller}/{action}
模塊既支持異步加載,也支持同步加載。默認(rèn)是異步加載,如果要同步加載,只需在模塊名稱后面加上-sync后綴,如模塊egg-born-module-aa-login-sync。
新建模塊進(jìn)入src/module目錄執(zhí)行腳手架,創(chuàng)建模塊文件骨架
$ egg-born module_relative_name
模塊前端開發(fā) 前端頁面路由EggBorn.js目前提供了2個(gè)模塊腳手架,分別是
module -- 全棧模塊模板
module-front -- 前端模塊模板
在front/src/routes.js中添加頁面路由,如
function load(name) { return require(`./pages/${name}.vue`).default; } export default [ { path: "welcome/:who", component: load("welcome") }, { path: "profile", component: load("profile"), meta: { requiresAuth: true } }, { path: "/login", component: load("login") }, ];
path: 路徑,支持參數(shù)。以/開頭,代表根頁面組件。login頁面組件通常這樣配置
component: 頁面組件對(duì)象
meta: 路由元數(shù)據(jù)
meta.requiresAuth: 如果頁面組件需要登錄,須設(shè)為true
在頁面中引用頁面組件,請(qǐng)使用絕對(duì)路徑,如
前端狀態(tài)管理
Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。EggBorn.js采用Vuex實(shí)現(xiàn)了完全隔離的模塊狀態(tài)管理機(jī)制。
在front/src/store.js中添加狀態(tài),如
export default function(Vue) { return { state: { message: "hello world", }, }; }
在頁面組件中訪問本模塊狀態(tài)
const message = this.$local.state.message;
在頁面組件中訪問其他模塊狀態(tài)
const message = this.$store.state[providerId][moduleName].message;
前端參數(shù)配置更多信息,請(qǐng)參閱: Vuex
在front/src/config/config.js中添加配置信息,如
export default { mode: 1, };
只支持在頁面組件中訪問本模塊內(nèi)部的參數(shù)配置
const mode = this.$config.mode;前端國際化
在front/src/config/locale目錄添加國際化文件
zh-cn.js文件中的語言定義示例如下
export default { mode: "模式", "Hello world! I"m %s.": "您好,世界!我是%s。", };
國際化語言采取全局合并的方式,有利于語言資源的共享,在頁面組件中訪問方式如下
const mode = this.$text("mode"); const message = this.$text("Hello world! I"m %s.","zhennann");模塊后端開發(fā) 后端api路由
在backend/src/routes.js中添加api路由,如
const home = require("./controller/home.js"); module.exports = [ { method: "get", path: "home/index", controller: home, action: "index", transaction: true }, ];
method: get/post等方法
path: 路徑,支持參數(shù)
component: Controller對(duì)象
action: Controller方法,如果不設(shè)置,則自動(dòng)采用path尾部單詞
transaction: 默認(rèn)為false,如果設(shè)為true,則啟用數(shù)據(jù)庫事務(wù)
在前端頁面組件中訪問本模塊api路由
this.$api.get("home/index").then(data => { }).catch(err => { });
在前端頁面組件中訪問其他模塊api路由
this.$api.get("/providerId/moduleName/home/index").then(data => { }).catch(err => { });后端Controller
后端Controller的實(shí)現(xiàn)方式與Egg.js保持一致
module.exports = app => { class HomeController extends app.Controller { async index() { const message = await this.service.home.index(); this.ctx.success(message); } } return HomeController; };
后端Service更多信息,請(qǐng)參閱: Egg.js Controller
Service用于封裝業(yè)務(wù)邏輯,供Controller調(diào)用,實(shí)現(xiàn)方式與Egg.js保持一致。
module.exports = app => { class Home extends app.Service { async index() { const res = await this.ctx.db.queryOne("show tables"); return res; } } return Home; };
后端Controller調(diào)用與Egg.js不同之處在于,Service使用ctx.db操作數(shù)據(jù)庫,從而自動(dòng)支持?jǐn)?shù)據(jù)庫事務(wù)。
更多信息,請(qǐng)參閱: Egg.js Service
為了支持大型Web系統(tǒng)的開發(fā),EggBorn.js支持模塊后端Controller之間的調(diào)用,如
const message = await this.ctx.performAction({ method: "get", url: "home/index", query: { username: "kevin", }, params: { mode: 1, }, body: { content: "ready", }, });
后端數(shù)據(jù)庫操作method: get/post等方法
url: 訪問本模塊的Controller使用相對(duì)路徑,訪問其他模塊的Controller使用以/開頭的絕對(duì)路徑。
query、params、body: 與常規(guī)的Controller參數(shù)保持一致
后端數(shù)據(jù)庫操作與Egg.js保持一致
后端數(shù)據(jù)庫事務(wù)更多信息,請(qǐng)參閱: Egg.js MySQL
EggBorn.js提供了更為便利的數(shù)據(jù)庫事務(wù)實(shí)現(xiàn)方式,只需在后端api路由記錄中配置transaction參數(shù),Service使用ctx.db操作數(shù)據(jù)庫。
如果是主Controller通過ctx.performAction調(diào)用子Controller,數(shù)據(jù)庫事務(wù)開啟規(guī)則如下:
主Controller配置 | 子Controller配置 | 子Controller實(shí)際啟用 |
---|---|---|
true | true | true |
true | false | true |
false | true | true |
false | false | false |
在backend/src/config/config.js中添加配置信息,如
module.exports = appInfo => { const config = {}; config.message = "Hello world! I"m %s."; return config; };
訪問本模塊內(nèi)部的參數(shù)配置示例如下
const message = this.ctx.config.message;后端國際化
在backend/src/config/locale目錄添加國際化文件
zh-cn.js文件中的語言定義示例如下
module.exports = { "Hello world! I"m %s.": "您好,世界!我是%s。", "not found": "未發(fā)現(xiàn)", };
國際化語言采取全局合并的方式,有利于語言資源的共享,訪問方式如下
const notFound = this.ctx.text("not found"); const message = this.ctx.text("Hello world! I"m %s.", "zhennann");后端錯(cuò)誤處理
在backend/src/config/errors.js文件中添加錯(cuò)誤代碼
// error code should start from 1001 module.exports = { 1001: "not found", };
返回錯(cuò)誤信息示例如下
this.ctx.fail(1001);
也可拋出異常示例如下
this.ctx.throw(1001);模塊管理 模塊依賴
EggBorn.js通過package.json文件管理模塊依賴關(guān)系。
比如,模塊aa-module1依賴aa-module2,需要在模塊aa-module1的package.json文件中作如下配置
{ "name": "egg-born-module-aa-module1", "version": "0.0.1", "eggBornModule": { "dependencies": { "aa-module2": "0.0.1" } }, "dependencies": { "egg-born-module-aa-module2": "^0.0.1" } }
模塊數(shù)據(jù)版本設(shè)置"egg-born-module-aa-module2": "^0.0.1",是為了在安裝模塊aa-module1時(shí)自動(dòng)安裝模塊aa-module2。如果模塊沒有公開發(fā)布,就不必設(shè)置。
模塊一般都要操作數(shù)據(jù)庫,當(dāng)模板版本升級(jí)時(shí),數(shù)據(jù)庫結(jié)構(gòu)也有可能變動(dòng)。EggBorn.js實(shí)現(xiàn)了模塊數(shù)據(jù)版本的管理,便于業(yè)務(wù)模塊的積累沉淀。
在模塊的package.json文件中配置fileVersion為當(dāng)前數(shù)據(jù)版本
{ "name": "egg-born-module-aa-module1", "version": "0.0.1", "eggBornModule": { "fileVersion": 1 } }
在模塊后端添加Api路由
{ method: "post", path: "version/update", controller: version }
添加version Controller
module.exports = app => { class VersionController extends app.Controller { async update() { await this.service.version.update(this.ctx.getInt("version")); this.ctx.success(); } } return VersionController; };
添加version Service
module.exports = app => { class Version extends app.Service { async update(version) { if (version === 1) { // do something } } } return Version; };
模塊發(fā)布當(dāng)啟動(dòng)后端服務(wù)時(shí),EggBorn.js自動(dòng)檢測模塊數(shù)據(jù)版本的變化,并執(zhí)行相應(yīng)的路由,完成數(shù)據(jù)的版本升級(jí)。
當(dāng)項(xiàng)目中的模塊代碼穩(wěn)定后,可以將模塊公開發(fā)布,貢獻(xiàn)到開源社區(qū)。也可以在公司內(nèi)部建立npm私有倉庫,然后把模塊發(fā)布到私有倉庫,形成公司資產(chǎn),便于重復(fù)使用。
模塊發(fā)布步驟如下
$ cd path/to/module -- 進(jìn)入模塊目錄 $ npm install -- 安裝模塊依賴 $ npm run build:front -- 構(gòu)建前端代碼 $ npm run build:backend -- 構(gòu)建后端代碼 $ npm publish -- 發(fā)布至npm倉庫測試驅(qū)動(dòng)
目前只支持后端測試驅(qū)動(dòng)
后端Controller測試在backend/test/controller目錄添加Controller測試文件
// controller/home.test.js const { app, mock, assert } = require("egg-mock/bootstrap"); const parseMockUrl = function(url) { const prefix = app.mockUtil.parseUrlFromPackage(__dirname); return `${prefix}${url}`; }; describe("test/controller/home.test.js", () => { it("action:index", async () => { const result = await app.httpRequest().get(parseMockUrl("home/index")); assert(result.body.code === 0); }); });后端Service測試
在backend/test/service目錄添加Service測試文件
// service/home.test.js const { app, mock, assert } = require("egg-mock/bootstrap"); const parseMockUrl = function() { return app.mockUtil.parseUrlFromPackage(__dirname); }; describe("test/service/home.test.js", () => { it("index", async () => { const ctx = app.mockContext({ mockUrl: parseMockUrl() }); const message = await ctx.service.home.index(); assert(message); }); });執(zhí)行測試
在項(xiàng)目根目錄執(zhí)行測試
$ npm run test:backend $ npm run cov:backend前端架構(gòu)配置 前端啟動(dòng)文件
前端架構(gòu)提供兩種方案
Vue.js + Framework7
Vue.js + Vue Router
Framework7是移動(dòng)開發(fā)專屬UI界面庫,內(nèi)置路由機(jī)制。
Vue Router是Vue.js官方路由庫,使用Vue Router可搭配其他各種UI界面庫。
在src/front/main.js文件中進(jìn)行切換
// choose one // framework7 import main from "./framework7/main.js"; // vuerouter // import main from "./vuerouter/main.js"; // export export default main;前端參數(shù)配置
src/front/config/config.js文件中的參數(shù)配置可以覆蓋模塊的參數(shù)
export default{ module: { "aa-hello": { mode: 2, }, }, };前端國際化
在src/front/config/locale目錄添加國際化文件,可以覆蓋模塊的國際化語言
zh-cn.js文件中的語言定義示例如下
export default { mode: "模式", };后端架構(gòu)配置 后端架構(gòu)
后端架構(gòu)基于Egg.js,完整支持Egg.js提供的所有功能與特性
后端參數(shù)配置更多信息,請(qǐng)參閱: Egg.js
src/backend/config/config.default.js文件中的參數(shù)配置可以覆蓋模塊的參數(shù)
module.exports = appInfo => { const config = {}; // module config config.module = { "aa-hello": { mode: 2, }, }; return config; };后端國際化
在src/backend/config/locale目錄添加國際化文件,可以覆蓋模塊的國際化語言
zh-cn.js文件中的語言定義示例如下
module.exports = { mode: "模式", };項(xiàng)目部署 構(gòu)建前端代碼
$ npm run build:front啟動(dòng)后端服務(wù)
$ npm run start:backend停止后端服務(wù)
$ npm run stop:backend后端服務(wù)啟動(dòng)參數(shù)配置
編輯build/config.js文件
// backend const backend = { port: 7002, hostname: "127.0.0.1", };nginx配置
強(qiáng)烈建議使用nginx托管前端靜態(tài)資源,并反向代理后端服務(wù),配置如下
server { listen 80; server_name example.com www.example.com; set $node_port 7002; root /path/to/www; location /api/ { proxy_http_version 1.1; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_set_header X-NginX-Proxy true; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; proxy_pass http://127.0.0.1:$node_port$request_uri; proxy_redirect off; } }GitHub貢獻(xiàn)
有任何疑問,歡迎提交 issue, 或者直接修改提交 PR!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/89352.html
摘要:文檔官網(wǎng)文檔演示是什么是一款頂級(jí)全棧開發(fā)框架。不重復(fù)造輪子,而是采用業(yè)界最新的開源技術(shù),進(jìn)行全棧開發(fā)的最佳組合。漸進(jìn)式開發(fā)由于模塊的高度內(nèi)聚,可以將業(yè)務(wù)以模塊的形式沉淀,在多個(gè)項(xiàng)目中重復(fù)使用,既可貢獻(xiàn)到開源社區(qū),也可部署到公司內(nèi)部私有倉庫。 文檔 官網(wǎng) && 文檔 演示 PC:https://admin.cabloy.com Mobile: showImg(https://seg...
摘要:掘金日?qǐng)?bào)第四期使用怎么能不知道這些插件合集掘金日?qǐng)?bào)主打分享優(yōu)質(zhì)深度技術(shù)內(nèi)容,技術(shù)內(nèi)容分前端后端產(chǎn)品設(shè)計(jì)工具資源和一些有趣的東西。目前已經(jīng)涵蓋了的相關(guān)資源鏈接,供大家參考與學(xué)習(xí)。 【掘金日?qǐng)?bào)】第四期 使用Sublime?怎么能不知道這些 Sublime 插件合集! 掘金日?qǐng)?bào)主打分享優(yōu)質(zhì)深度技術(shù)內(nèi)容,技術(shù)內(nèi)容分:前端、后端、Android、iOS、產(chǎn)品設(shè)計(jì)、工具資源和一些有趣的東西。 前端...
摘要:掘金日?qǐng)?bào)第四期使用怎么能不知道這些插件合集掘金日?qǐng)?bào)主打分享優(yōu)質(zhì)深度技術(shù)內(nèi)容,技術(shù)內(nèi)容分前端后端產(chǎn)品設(shè)計(jì)工具資源和一些有趣的東西。目前已經(jīng)涵蓋了的相關(guān)資源鏈接,供大家參考與學(xué)習(xí)。 【掘金日?qǐng)?bào)】第四期 使用Sublime?怎么能不知道這些 Sublime 插件合集! 掘金日?qǐng)?bào)主打分享優(yōu)質(zhì)深度技術(shù)內(nèi)容,技術(shù)內(nèi)容分:前端、后端、Android、iOS、產(chǎn)品設(shè)計(jì)、工具資源和一些有趣的東西。 前端...
摘要:為了便于您更清晰的理解的體系架構(gòu),在這里我將為您展示年開發(fā)者知識(shí)圖譜,它包含了所有開發(fā)過程中的關(guān)鍵部分。在數(shù)據(jù)展示前端導(dǎo)入導(dǎo)出圖表面板數(shù)據(jù)綁定等場景無需大量代碼開發(fā)和測試,可極大節(jié)省企業(yè)研發(fā)成本并降低交付風(fēng)險(xiǎn)。 作為 Vue 的初學(xué)者,您或許已經(jīng)聽過很多關(guān)于它的專業(yè)術(shù)語了,例如:單頁面應(yīng)用程序、異步組件、服務(wù)器端呈現(xiàn)等,您可能還聽過和Vue經(jīng)常一起被提到的工具和庫,如Vuex、Webp...
摘要:月日,官方團(tuán)隊(duì)在中宣布將對(duì)進(jìn)行重大更改,主要包括將代碼庫從移植到,不再支持和,并為新增了一些功能等,這個(gè)更改項(xiàng)目代號(hào)為,目的是增強(qiáng)優(yōu)勢,彌補(bǔ)弱勢。調(diào)查結(jié)果顯示在年度榮獲最受歡迎的編程語言。 訂閱 / 投稿:https://github.com/txd-team/monthly本期小編:x-cold (尹摯) 新聞快報(bào) 重磅消息:Github 宣布私有倉庫免費(fèi),同期還上線了星標(biāo)話題?(...
閱讀 1837·2021-11-11 16:55
閱讀 759·2019-08-30 15:53
閱讀 3598·2019-08-30 15:45
閱讀 746·2019-08-30 14:10
閱讀 3275·2019-08-30 12:46
閱讀 2132·2019-08-29 13:15
閱讀 2034·2019-08-26 13:48
閱讀 942·2019-08-26 12:23