欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

egg.js的基本使用和調(diào)用數(shù)據(jù)庫的方法示例

 更新時(shí)間:2019年05月18日 12:10:07   作者:小胖龍  
這篇文章主要介紹了egg.js的基本使用和調(diào)用數(shù)據(jù)庫的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

首先,整個(gè)項(xiàng)目的創(chuàng)建命令:

npm i egg-init -g //安裝egg
egg-init egg-example --type=simple //初始化一個(gè)egg模板例子 后面的type跟的是模板類型這里是簡單的
cd egg-example//進(jìn)入例子
npm i //安裝依賴

可以去官方教程查看基本配置的講解。

直接說使用,簡單看過Egg的文檔,官方文檔對于入門還是很實(shí)用的,再配合一些別人的攻略很容易入門上手就可以使用。

首先router.js:

'use strict';

/**
 * @param {Egg.Application} app - egg application
 */
module.exports = app => {
 const { router, controller } = app;
 router.get('/', controller.home.index);
 router.get('/custom',controller.customController.custonIndex); //自定義controller的路由
};

router.js中定義了我們的路由規(guī)則,所有的請求都會(huì)通過這個(gè)路由規(guī)則去找對應(yīng)的Controller,這樣也可以做到統(tǒng)一管控(如同前端初始化所有組件吧)。

接下來就是Controller控制層:

'use strict';

const Controller = require('egg').Controller;

class CustomController extends Controller {
  async custonIndex() { //注意這里要定義成異步方法防止請求被阻塞
    //let {id} = this.ctx.params; // 獲取路由參數(shù)
    //let {name} = this.ctx.query; // 獲取用戶入?yún)?
    let options = {id:'5', name:2}
    
    let info = await this.ctx.service.customService.getInfo(options);//調(diào)用Service層傳參
    處理,返回結(jié)果賦值
    
    this.ctx.body = {
      code: 200,
      data: info
    };//返回體
    this.ctx.status = 200;
  }
}

module.exports = CustomController;

發(fā)送請求會(huì)調(diào)用Controller中的方法,Controller中主要工作是接受用戶的參數(shù)并進(jìn)行處理,然后將處理好的參數(shù)發(fā)送給Service層,然后把Service的結(jié)果返回給用戶。

其中對參數(shù)的處理包括但不僅限于參數(shù)校驗(yàn)和參數(shù)拼裝,當(dāng)然也可以直接返回不走Service,都在Controller層做處理,但是不建議這樣做。

服務(wù)層(Service):

const Service = require('egg').Service;

class CustimService extends Service {
  async getInfo(options) {
    const results = await this.app.mysql.select('test',{id:5});
    return results[0].name;
  }
}

module.exports = CustimService;

Service層拿到Controller層的數(shù)據(jù)之后,根據(jù)條件執(zhí)行對數(shù)據(jù)庫或者其他操作,最終將結(jié)果返回,一個(gè)請求的簡單流程就算是完成了

配置MySQL在egg-project\config\config.default.js里面,直接放上我的配置,具體起她的數(shù)據(jù)庫配置方法可以自查。

'use strict';

module.exports = appInfo => {
 const config = exports = {
   mysql:{
     // 單數(shù)據(jù)庫信息配置
     client: {
       // host
       host: '44.44.44.44',
       // 端口號
       port: '3306',
       // 用戶名
       user: 'mysq',
       // 密碼
       password: '359359',
       // 數(shù)據(jù)庫名
       database: 'mysql_db',
     },
     // 是否加載到 app 上,默認(rèn)開啟
     app: true,
     // 是否加載到 agent 上,默認(rèn)關(guān)閉
     agent: false,
   }
 };

 // use for cookie sign key, should change to your own and keep security
 config.keys = appInfo.name + '_17792_5967';

 // add your config here
 config.middleware = [];

 return config;
};

這樣,你就打通了egg和數(shù)據(jù)庫之間的基本操作了。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript 九種跨域方式實(shí)現(xiàn)原理

    JavaScript 九種跨域方式實(shí)現(xiàn)原理

    這篇文章主要介紹了JavaScript 九種跨域方式實(shí)現(xiàn)原理,什么是跨域,以及有哪幾種跨域方式,這是本文要探討的內(nèi)容。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-02-02
  • JS:window.onload的使用介紹

    JS:window.onload的使用介紹

    window.onload在某些情況下還是比較實(shí)用的,比如加載時(shí)執(zhí)行哪些腳本等等,下面有幾個(gè)不錯(cuò)的示例,需要的朋友可以參考下
    2013-11-11
  • 微信小程序?qū)崿F(xiàn)折疊與展開文章功能

    微信小程序?qū)崿F(xiàn)折疊與展開文章功能

    最近做項(xiàng)目遇到這樣的需求,頁面折疊超出的的部分顯示省略號,點(diǎn)擊展開后顯示全部內(nèi)容。具體實(shí)現(xiàn)代碼大家跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-06-06
  • js中浮點(diǎn)型運(yùn)算BUG的解決方法說明

    js中浮點(diǎn)型運(yùn)算BUG的解決方法說明

    本篇文章主要是對js中浮點(diǎn)型運(yùn)算BUG的解決方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • easyui combobox開啟搜索自動(dòng)完成功能的實(shí)例代碼

    easyui combobox開啟搜索自動(dòng)完成功能的實(shí)例代碼

    下面小編就為大家?guī)硪黄猠asyui combobox開啟搜索自動(dòng)完成功能的實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-11-11
  • 基于iScroll實(shí)現(xiàn)下拉刷新和上滑加載效果

    基于iScroll實(shí)現(xiàn)下拉刷新和上滑加載效果

    這篇文章主要為大家詳細(xì)介紹了基于iScroll實(shí)現(xiàn)下拉刷新和上滑加載效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 淺談JavaScript 的執(zhí)行順序

    淺談JavaScript 的執(zhí)行順序

    JavaScript是一種描述型腳本語言,它不同于java或C#等編譯性語言,它不需要進(jìn)行編譯成中間語言,而是由瀏覽器進(jìn)行動(dòng)態(tài)地解析與執(zhí)行。如果你不能理解javaScript語言的運(yùn)行機(jī)制,或者簡單地說,你不能掌握javascript的執(zhí)行順序,那你就猶如伯樂駕馭不了千里馬
    2015-08-08
  • JS跳轉(zhuǎn)手機(jī)站url的若干注意事項(xiàng)

    JS跳轉(zhuǎn)手機(jī)站url的若干注意事項(xiàng)

    去年年底開發(fā)了一個(gè)手機(jī)站平臺(tái),遇到了很多坎,今天小編給大家分享下使用JS跳轉(zhuǎn)手機(jī)站url的若干注意事項(xiàng),需要的朋友參考下吧
    2017-10-10
  • ztree獲取當(dāng)前選中節(jié)點(diǎn)子節(jié)點(diǎn)id集合的方法

    ztree獲取當(dāng)前選中節(jié)點(diǎn)子節(jié)點(diǎn)id集合的方法

    這篇文章主要介紹了ztree獲取當(dāng)前選中節(jié)點(diǎn)子節(jié)點(diǎn)id集合的方法,實(shí)例分析了ztree的方法transformToArray使用技巧,需要的朋友可以參考下
    2015-02-02
  • 如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求的控制詳解

    如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求的控制詳解

    通常為了減少頁面加載時(shí)間,先把核心內(nèi)容顯示處理,頁面加載完成后再發(fā)送ajax請求獲取其他數(shù)據(jù),這時(shí)就可能產(chǎn)生多個(gè)ajax請求,為了用戶體驗(yàn),最好是發(fā)送并行請求,這篇文章主要給大家介紹了關(guān)于如何基于JS實(shí)現(xiàn)Ajax并發(fā)請求控制的相關(guān)文章,需要的朋友可以參考下
    2021-08-08

最新評論