国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

EggBorn.js:一款頂級(jí)Javascript全棧開發(fā)框架

dayday_up / 1076人閱讀

摘要:是什么是一款頂級(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)。

EggBorn.js重點(diǎn)解決什么問題:業(yè)務(wù)模塊化

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)了第三種解決方案:

3 頁面組件按業(yè)務(wù)需求歸類,進(jìn)行模塊化,并且實(shí)現(xiàn)了模塊的異步加載機(jī)制,從而彌合了前兩種解決方案的缺點(diǎn),完美滿足大型Web應(yīng)用業(yè)務(wù)持續(xù)增長的需求。

EggBorn.js的技術(shù)特點(diǎn)

業(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,從此可復(fù)用的不僅僅是組件,還有業(yè)務(wù)模塊。

快速上手 安裝EggBorn.js腳手架
$ npm install -g egg-born
新建項(xiàng)目
$ egg-born project_name
$ cd project_name
$ npm install

EggBorn.js目前提供了2個(gè)項(xiàng)目腳手架,分別是

front-backend-mysql -- 前后端全棧項(xiàng)目模板

front -- 前端項(xiàng)目模板,后端可采用其他方案

配置mysql連接參數(shù)

如果采用了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:front
EggBorn.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é)命名信息如下:

providerId: a

moduleName: version

fullName: egg-born-module-a-version

relativeName: a-version

前端頁面路由地址: /a/version/{page}

后端API路由地址:/a/version/{controller}/{action}

加載機(jī)制

模塊既支持異步加載,也支持同步加載。默認(rèn)是異步加載,如果要同步加載,只需在模塊名稱后面加上-sync后綴,如模塊egg-born-module-aa-login-sync

新建模塊

進(jìn)入src/module目錄執(zhí)行腳手架,創(chuàng)建模塊文件骨架

$ egg-born module_relative_name

EggBorn.js目前提供了2個(gè)模塊腳手架,分別是

module -- 全棧模塊模板

module-front -- 前端模塊模板

模塊前端開發(fā) 前端頁面路由

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;

更多信息,請(qǐng)參閱: Vuex

前端參數(shù)配置

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;
};

更多信息,請(qǐng)參閱: Egg.js Controller

后端Service

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;
};

與Egg.js不同之處在于,Service使用ctx.db操作數(shù)據(jù)庫,從而自動(dòng)支持?jǐn)?shù)據(jù)庫事務(wù)。

更多信息,請(qǐng)參閱: Egg.js Service

后端Controller調(diào)用

為了支持大型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",
  },
});

method: get/post等方法

url: 訪問本模塊的Controller使用相對(duì)路徑,訪問其他模塊的Controller使用以/開頭的絕對(duì)路徑。

queryparamsbody: 與常規(guī)的Controller參數(shù)保持一致

后端數(shù)據(jù)庫操作

后端數(shù)據(jù)庫操作與Egg.js保持一致

更多信息,請(qǐng)參閱: Egg.js MySQL

后端數(shù)據(jù)庫事務(wù)

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
后端參數(shù)配置

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è)置"egg-born-module-aa-module2": "^0.0.1",是為了在安裝模塊aa-module1時(shí)自動(dòng)安裝模塊aa-module2。如果模塊沒有公開發(fā)布,就不必設(shè)置。

模塊數(shù)據(jù)版本

模塊一般都要操作數(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;
};

當(dāng)啟動(dòng)后端服務(wù)時(shí),EggBorn.js自動(dòng)檢測模塊數(shù)據(jù)版本的變化,并執(zhí)行相應(yīng)的路由,完成數(shù)據(jù)的版本升級(jí)。

模塊發(fā)布

當(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提供的所有功能與特性

更多信息,請(qǐng)參閱: Egg.js

后端參數(shù)配置

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

相關(guān)文章

  • Cabloy.js:基于EggBorn.js開發(fā)一款頂級(jí)Javascript全棧業(yè)務(wù)開發(fā)框架

    摘要:文檔官網(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...

    tomlingtm 評(píng)論0 收藏0
  • 前端學(xué)習(xí)資源

    摘要:掘金日?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ì)、工具資源和一些有趣的東西。 前端...

    xzavier 評(píng)論0 收藏0
  • 前端學(xué)習(xí)資源

    摘要:掘金日?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ì)、工具資源和一些有趣的東西。 前端...

    weij 評(píng)論0 收藏0
  • Vue 2019開發(fā)者圖譜

    摘要:為了便于您更清晰的理解的體系架構(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...

    cgspine 評(píng)論0 收藏0
  • 前端小報(bào) - 201901 月刊

    摘要:月日,官方團(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)話題?(...

    soasme 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<