egg(15)--基类

base.js

封装公共方法,如success,error

目录结构

clipboard.png

文件内容

router.js
module.exports = app => {
  const { router, controller } = app;
  router.get('/', controller.home.index);

  router.get('/login', controller.user.login);

  router.get('/register', controller.user.register);

  router.post('/doLogin', controller.user.doLogin);

  router.post('/doRegister', controller.user.doRegister);
};
core/base.js
'use strict';

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

class BaseController extends Controller {
  async success(redirectUrl) {
    await this.ctx.render('public/success', {
      redirectUrl: redirectUrl || '/',
    });
  }
  async error(redirectUrl) {
    await this.ctx.render('public/error', {
      redirectUrl: redirectUrl || '/',
    });
  }
}

module.exports = BaseController;
controller/user.js
'use strict';

const BaseController = require('../core/base.js');

class UserController extends BaseController {
  async login() {
    await this.ctx.render('login');
  }
  async register() {
    await this.ctx.render('register');
  }

  async doLogin() {
    await this.success('/login');
  }
  async doRegister() {
    await this.error('/register');
  }
}

module.exports = UserController;
error.html
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">


    <meta http-equiv="refresh" content="3;url={{redirectUrl}}">

    <title>Document</title>
</head>

<body>

    <h1 style="font-size: 60px; color:red;">失败 error!</h1>


</body>

</html>
success.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <meta http-equiv="refresh" content="3;url={{redirectUrl}}"> 


    <title>Document</title>
</head>
<body>
    
    
    
    <h1 style="font-size: 60px;">成功 success ! </h1>

</body>
</html>

效果

路由跳转顺序
clipboard.png

clipboard.png

clipboard.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值