Daze.js 是一款 Node.js 服务端 Web 开发框架,底层基于 IOC 容器模式实现,使用装饰器进行依赖注入,结合 AOP 模式编程
由于使用装饰器进行依赖注入,所以依赖 Babel 生态
基于 IOC 容器模式设计,模块深度解耦
支持 AOP 编程,对业务逻辑的各个部分进行隔离
路由去中心化,通过注入实现路由定义,提升阅读质量
内置多种组件类型,应对复杂场景
支持自定义提供者,具备高扩展能力
自动加载组件自动分类注册,自动化体验极佳
更多...
做最好的开发体验
const { Controller, Route, Http } = require('@dazejs/framework') @Route('/superman') class Superman extends Controller { @Http.Get('/create') create() { return this.response().Created() } }复制代码
上面的示例是一个控制器的代码,使用 @Route 装饰器表示这是一个路由控制器,并且路由前缀为 /superman
, 控制器继承了基础控制器 Controller
, 表示这是一个控制器模块,使用 Http.Get 装饰器开放 /superman/create
访问路径,我们可以使用 GET /superman/create
访问该资源,使用 this.response().Created()
创建状态码为 201 Created
的响应
. ├── dist // 打包目标目录 ├── logs // 日志目录 ├── package.json ├── public // 静态资源目录 ├── src // 源码目录 │ ├── app // 应用目录 │ │ ├── controller // 控制器目录(推荐) │ │ ├── middleware // 中间件目录(推荐) │ │ ├── service // 服务类目录(推荐) │ │ ├── resource // API 资源目录(推荐) │ │ ├── component // 通用组件目录(推荐) │ │ ├── validator // 验证器目录(推荐) │ ├── config // 应用配置目录 │ └── index.js // 应用入口文件 └── views // 视图文件目录复制代码
src/app
下的目录结构可自行定义
路由参数框架已经通过控制器方法自动注入, 我们可以通过定义路由参数的顺序来获取
const { Controller, Route, Http } = require('@dazejs/framework') @Route('/superman') class Superman extends Controller { @Http.Get('/create/:name/:driver') create(name, driver) { return { name, driver } } }复制代码
当我们访问 /superman/create/xiaoming/lily
, 我们就可以通过参数直接获取 name
和 driver
控制器中,可以直接通过控制器实例获取请求实例
const { Controller, Route, Http } = require('@dazejs/framework') @Route('/superman') class Superman extends Controller { @Http.Get('/create') create() { const name = this.request.getParam('name') return name } }复制代码
在上述例子中,如果我们访问 /superman/create?name=xxx
, 我们就可以通过 this.request.getParam('name')
获取到 name 的值:xxx
大部分情况我们只需要在控制器直接 return
数据即可返回结果,框架另外还支持返回资源实例,视图实例,响应实例等
这里我们先介绍下响应实例,可以直接通过控制器方法属性 this.response(data, code, headers)
创建响应实例:
const { Controller, Route, Http } = require('@dazejs/framework') @Route('/superman') class Superman extends Controller { @Http.Get('/create') create() { return this.response('data', 200, { 'conetent-type': 'application/json' }) } }复制代码
响应实例还提供了更多有用的方法,具体可以查看官方文档(文章最后会有)
Daze.js
目前刚发布 1.0 版本,功能已经很多,一篇文章介绍不完,大家可以期待后续的文章或者关注项目了解更多,还有更多的功能迭代计划
后续还有更多深入介绍使用方法和原理的文章
这仅仅是开源的第一步
websocket
granphQL
Dubbo
DB
ORM
更多 ...
大家有更多的想法可以去 issue 提出: github.com/dazejs/daze…
官网:dazejs.org
项目地址: github.com/dazejs/daze