likes
comments
collection
share

属于Node的Spring服务端框架 a2n

作者站长头像
站长
· 阅读数 21

a2n

一套基于Spring设计理念开发的NodeJs服务端框架。

NPM    Github

作为一名软件开发搬砖仔,今年年初毕业后找了一份前端开发的工作,技术栈主要是 Vue,虽然工作内容只有前端,但是自己也是懂一些后端。平时我比较倾向于用 Java Spring 来写接口,在深入学习 Spring 的设计理念之后,就想着自己也写一个实用的框架出来,但是 Java 出色的框架已经很多了,我也不是专业的 Java 工程师,所以选择了使用 Node 来开发一个服务端框架,对 Node 感兴趣的小伙伴可以前往 Github 或者 NPM 下载体验。

✨ 特性

  • 🌍 基于 NodeJs+Express 进行开发。
  • 🌈 采用了 Java 语言 Spring 框架的设计理念,实现了 Spring 中 AOP,IOC 等主要的功能。
  • ⚙️ 在体验 Spring 设计模式的同时,又可以使用 npm 强大的插件功能。
  • 🛡 使用 TypeScript 开发,提供完整的类型定义文件。
  • 📦 如果你曾经是一个Java程序员并且有一定的Js基础,那么可以以极低的学习成本使用a2n进行开发。

📦 搭建

  • 安装脚手架
npm install a2n-cli -g
  • 初始化项目基础代码环境
a2n-cli create <project-name>
  • 进入项目目录
cd <project-name>
  • 安装依赖
npm install
  • 启动服务
npm run dev
  • 打包
npm run build

🔨 项目结构

  • 配置文件 a2n.config.js
module.exports = {
  // 组件扫描路径,该路径下的js,ts文件将会被容器扫描,默认src
  componentScan: 'src',
  // 服务启动端口号
  port: 8088,
  // 一些自定义的配置项
  datasource: {
    url: '123lll'
  }
}
  • 启动入口 main

main 目录下的文件为项目启动和打包相关的文件,start.ts 为入口文件,config 中为本地开发和打包时的 webpack 配置文件,由于本地开发环境需要实现代码热更新,因此将 webpack 配置文件进行拆分。

  • ts语言配置

通过根目录下的 tsconfig.json 配置ts语言能力。

🌈 如何使用

编写接口

import { Control, Get, Query, Post, Body, Put, Req, Res, Request, Response } from 'a2n';

/**
 * 使用@Control标记一个Class
 * Class下的@Get@Post@Delete@Put方法都会被注册为接口,方法return的值作为接口返回值
 */
@Control("/user")
export default class UserControl{

  @Get("/get")
  get(@Query query: any, @Query("name") name: string){
    // 使用@Query注入url携带的参数,@Query("name")表示注入url参数中名称为name的参数
    return query.name
  }

  @Post("/post")
  get1(@Body body: any, @Body("name") name: string){
    // 使用@Body注入请求报文携带的参数,@Body("name")表示注入请求报文中名称为name的参数
    return body
  }

  @Put("/put")
  get1(@Req request: Request, @Res response: Response){
    // 使用@Req注入请求对象,@Res注入响应对象
    // 请求和响应对象使用参考express的Request、Response使用方法 https://nodejs.cn/express/4x/api/req/
  }

}