0.1.4 • Published 3 years ago

@ppzp/http-router v0.1.4

Weekly downloads
-
License
ISC
Repository
github
Last release
3 years ago

一个 js 框架,两个功能:路由、AOP

npm install @ppzp/http-router

皮皮仔宣言

路由

web 应用中,“路由”是一个重要的基础功能,即要解决:

当服务器收到一条 http 请求,由哪个函数,来处理这条请求

http-router 使用了类似 express 的处理方式:

router.post('/user', function() {
  // ...
})

AOP

另外,不同的请求,可能需要相同的处理逻辑
代码复用是任何应用面临的重要问题 http-router 是这样处理的:

function 公用函数(ctx, vege) {
  // ...
  vege(ctx) // 执行 vege,就是在执行下面的 handler666 函数
  // ...
}
router.post('/user', 公用函数, function handler666(ctx) {
  // ...
})

这看起来像 express,但不同的地方在于,公用函数其实是包裹handler666 函数
比如你可以这样:

function 公用函数(ctx, vege) {
  // vege 之前,先做预处理
  const result = vege(ctx)
  // vege 之后,再做后续处理
}
router.post('/user', 公用函数, function handler666(ctx) {
  // ...
})

就像一个三明治
上面是面包,中间是蔬菜(vegetable)或肉,下面还是面包

每一个公用函数都是一个三明治,它里面有一些蔬菜
而对公用函数“前面的”其他公用函数来说:
后面的公用函数,就是前面公用函数的“蔬菜”

使用

环境准备

仅需要一个普通的 node,最好 10 以上版本

如果没有,进入这个链接,下载相应版本

创建项目:

mkdir test-http-router # 创建项目目录
cd test-http-router # 进入项目目录
# 到这里,只是一个普通的文件夹

npm init -y # 使用 npm,初始化一个 node 项目
# 到这里,一个空的 node 项目就创建好了

npm install @ppzp/http-router # 在项目中安装 resh

案例

TODO

API

TODO

常见问题

TODO

最后

不保留任何版权(也实在没什么好保留的)
欢迎 pr、意见、批评

0.1.0

3 years ago

0.0.1

3 years ago

0.1.2

3 years ago

0.1.1

3 years ago

0.1.4

3 years ago

0.1.3

3 years ago

0.0.0

3 years ago