背景
koa-router路由越來越多,api下的router都要使用下面的方式引入,怎么才能方便快捷的將api下的所有文件都引入呢
這次記錄的就是如果將koa-router 一次性循環引入
const book = require('./app/api/v1/book')const classic = require('./app/api/v1/classic')// ...app.use(book.routes(), book.allowedMethods())app.use(classic.routes(), classic.allowedMethods())//...
文件目錄
koa-demo/ |-api/ |-books.js |-classic.js |-users.js |-articles.js |-package.json |-app.js
傳統方式引入router
app.js
const Koa = require('koa')const app = new Koa()const book = require('./app/api/v1/book')const classic = require('./app/api/v1/classic')app.use(book.routes(), book.allowedMethods())app.use(classic.routes(), classic.allowedMethods())app.listen(3333)
require-directory引入
require-directory用來遞歸地迭代指定的目錄,并返回這些模塊。
github
隨著文件增加,如何高效的開發就是我們要追求的事情了
首先
npm install require-directory
app.js
const Koa = require('koa')const app = new Koa()const Router = require('koa-router')// 使用require-directory加載路由文件夾下的所有routerconst requireDirectory = require('require-directory')// 將所有的路由加載上,自動加載代碼const modules = requireDirectory(module, './api', { visit: whenLoadModule })function whenLoadModule(obj) { if (obj instanceof Router) { app.use(obj.routes(), obj.allowedMethods()) }}app.listen(3333)
路由文件就按照傳統的方式寫就行
books.js
const Router = require('koa-router')const router = new Router()router.get('/v1/book/latest', (ctx, next) => { ctx.body = { key: 'book' }})module.exports = router
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。
新聞熱點
疑難解答