博文原创,转载附上本博文链接即可。
博主也很无奈,controller里,你login登录调用user权限里的方法肯定是无法避免的,你不可能都放一个类里,况且也没有多继承这种东西,也不适合你放extend/写扩展,不然你到时候挂载app,或ctx就太多了,想想,还是得controller层 2个js文件里的方法得相互可以引用才可以。
看来大佬都喜欢吃独食啊,百度个毛线没有,没事,关注博主吧,不是什么大佬,但是毕竟13年工作经验,摆在那。
本博文最终要实现的目标是:controller/a.js 可以调用controller/b.js的方法
好了,开始正题,说下我的解决方案:
2个js: a.js和b.js ,和路由router.js
路由router.js加入
router.get('/api/aaa', controller.a.test1);
a.js
- const { Controller } = require('egg');
- const bb= require('./b');
-
- /**
- * @Controller 登录模块
- */
- class UserController extends Controller {
- constructor(m){//这里相当于this了,亲,去看看es6构造函数那一章
- super(m)
- this.b=new bb(m)
- }
- /**
- * @summary 验证码
- * @description 测试swagger文档是否可用
- * @router get /api/verify
- */
- async test1() {
- let m=this,{app}=m;
- debugger
- m.b.conss();
- }
- }
- module.exports = UserController;
b.js
- const { Controller } = require('egg');
- /**
- * @Controller 登录模块
- */
- class UserController extends Controller {
- constructor(m){
- super(m)
- }
- /**
- * @summary 验证码
- * @description 测试swagger文档是否可用
- * @router get /api/verify
- */
- async conss() {
- let m=this,{app}=m;
- console.log(1)
- debugger
- }
- }
- module.exports = UserController;
接口访问
http://localhost:8033/api/aaa?id=1
博主原创,转载附上本博文的链接。