koa大型web项目中使用路由装饰器的方法示例


Posted in Javascript onApril 02, 2019

一、关于重复造轮子解释下

在npmjs上搜索关于koa路由装饰器的已经有那么几个包了,但是我从几个包中发现作者的思维仅仅限制于前端开发的思想,项目分层不明确,我们开发kow-web项目可以根据java-web中项目分层的思想来写项目,项目结构清晰明了,本人封装这个包也是参考了java-web开发过程中把项目分为四层架构。

1、controllers:路由的控制
2、servers:常用于一些业务逻辑的判断
3、dao:操作数据库的
4、models:关于建表的数据模型

二、关于koa2-router-decors包的使用步骤

1、构建一个项目,并创建分层目录

2、安装

npm install koa2-router-decors
// or
yarn add koa2-router-decors

3、在中间件中使用我们安装的包

import { resolve } from 'path';
import Route from 'koa2-router-decors';
// 可以写到config中统一配置
const API_VERSION = '/api/v1';
/**
 * @Description: 反转路径的方法
 * @param {String} 
 * @return: 
 */
const dir = path => resolve(__dirname, path);

/**
 * @Description: 路由中间件读取controllers中的装饰器配置
 * @param {type} 
 * @return: 
 */
export default (app) => {
 // 这个地方是要读取的文件夹目录
 const apiPath = dir('../controllers/*');
 // 实例化类并调用方法
 const route = new Route(app, apiPath, API_VERSION);
 route.init();
};

4、使用中间件

5、在controllers的文件夹中使用装饰器

@controller('/user')
export class UserController extends BaseController {
 constructor() {
  super();
 }
 /**
  * 
  * @api {post} /api/v1/user/create/ 添加用户
  * @apiDescription 创建用户的接口
  * @apiName createUser
  * @apiGroup users
  * @apiVersion 0.1.0
  * @apiParam {string} username="张三" 用户名
  * @apiParam {string} mobile 手机号码
  * @apiParam {string} email 邮箱
  * @apiParam {string} password 密码
  */
 @post('/create')
 @required({ body: ['username', 'mobile', 'password'] })
 async createUser(ctx) {
  const result = await UserServer.createUser(ctx.request.body);
  ctx.success(result);
 }
 ....
}

6、具体代码可以参考example中写的

三、关于example代码跑起来的说明

1、使用的是mysql

2、mysql建表sql

CREATE TABLE `user` (
 `id` int(11) NOT NULL AUTO_INCREMENT,
 `username` varchar(30) NOT NULL,
 `mobile` varchar(11) DEFAULT NULL,
 `email` varchar(20) DEFAULT NULL,
 `password` varchar(255) NOT NULL,
 `created_at` datetime DEFAULT CURRENT_TIMESTAMP,
 `updated_at` datetime DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
 PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8

3、在example的根目录下创建一个.env的文件

DB_HOST=数据库地址
DB_USERNAME=数据库连接名
DB_PASSWORD=数据库连接密码
DB_DATABASE=数据库名

四、源码地址,欢迎小伙伴提出问题,方便点赞一个

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery 1.3.2以上版本中出现pareseerror错误的解决方法
Jan 11 Javascript
JS焦点图切换,上下翻转
May 12 Javascript
document.write()及其输出内容的样式、位置控制
Aug 12 Javascript
JavaScript中匿名、命名函数的性能测试
Sep 04 Javascript
js行号显示的文本框实现效果(兼容多种浏览器 )
Oct 23 Javascript
JS实现浏览器状态栏文字闪烁效果的方法
Oct 27 Javascript
vue2.0在table中实现全选和反选的示例代码
Nov 04 Javascript
超出JavaScript安全整数限制的数字计算BigInt详解
Jun 24 Javascript
解决vue.js 数据渲染成功仍报错的问题
Aug 25 Javascript
深入浅析vue中cross-env的使用
Sep 12 Javascript
vue.js实现二级菜单效果
Oct 19 Javascript
vue中的mescroll搜索运用及各种填坑处理
Oct 30 Javascript
vue中v-text / v-html使用实例代码详解
Apr 02 #Javascript
Seajs源码详解分析
Apr 02 #Javascript
使用mixins实现elementUI表单全局验证的解决方法
Apr 02 #Javascript
移动端自适应flexible.js的使用方法(不用三大框架,仅写一个单html页面使用)推荐
Apr 02 #Javascript
基于vue实现web端超大数据量表格的卡顿解决
Apr 02 #Javascript
基于AngularJS拖拽插件ngDraggable.js实现拖拽排序功能
Apr 02 #Javascript
详解vue后台系统登录态管理
Apr 02 #Javascript
You might like
PHP中通过ADO调用Access数据库的方法测试不通过
2006/12/31 PHP
php 获取全局变量的代码
2011/04/21 PHP
PHP数据类型的总结分析
2013/06/13 PHP
使用ThinkPHP+Uploadify实现图片上传功能
2014/06/26 PHP
php使用GD创建保持宽高比缩略图的方法
2015/04/17 PHP
jquery checkbox全选、取消全选实现代码
2010/03/05 Javascript
js实现俄罗斯方块小游戏分享
2014/01/31 Javascript
ie9 提示'console' 未定义问题的解决方法
2014/03/20 Javascript
在myeclipse中如何加入jquery代码提示功能
2014/06/03 Javascript
基于javascript的COOkie的操作实现只能点一次
2014/12/26 Javascript
Javascript基础教程之break和continue语句
2015/01/18 Javascript
node+express制作爬虫教程
2016/11/11 Javascript
JS复制对应id的内容到粘贴板(Ctrl+C效果)
2017/01/23 Javascript
nodejs读写json文件的简单方法(必看)
2017/03/09 NodeJs
AngularJS 最常用的八种功能(基础知识)
2017/06/26 Javascript
原生js FileReader对象实现图片上传本地预览效果
2020/03/27 Javascript
基于Vue渲染与插件的加载顺序的问题详解
2018/03/05 Javascript
jQuery中的$是什么意思及 $. 和 $().的区别
2018/04/20 jQuery
vue项目配置同一局域网可使用ip访问的操作
2020/10/23 Javascript
python标准日志模块logging的使用方法
2013/11/01 Python
python输出当前目录下index.html文件路径的方法
2015/04/28 Python
Python简单基础小程序的实例代码
2019/04/28 Python
Django中的session用法详解
2020/03/09 Python
django的autoreload机制实现
2020/06/03 Python
Python魔术方法专题
2020/06/19 Python
使用python脚本自动生成K8S-YAML的方法示例
2020/07/12 Python
Html5之svg可缩放矢量图形_动力节点Java学院整理
2017/07/17 HTML / CSS
乌克兰时尚鞋子和衣服购物网站:Born2be
2018/05/24 全球购物
方法名是否可以与构造器的名字相同
2012/06/04 面试题
外企C语言笔试题
2013/11/10 面试题
社区党建工作汇报材料
2014/10/27 职场文书
让子弹飞观后感
2015/06/11 职场文书
关于环保的广播稿
2015/12/17 职场文书
评估“风险”创业计划的几大要点
2019/08/12 职场文书
南阳市白酒市场的调查报告
2019/11/08 职场文书
VS2019连接MySQL数据库的过程及常见问题总结
2021/11/27 MySQL