属于Node的Spring服务端框架 a2n

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进行开发。

📦 搭建

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

🔨 项目结构

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

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

  • ts语言配置

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

🌈 如何使用

编写接口

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/
  }

}
相关推荐
明辉光焱7 小时前
Node.js笔记
javascript·笔记·node.js
明辉光焱8 小时前
使用yarn,如何编译打包electron?
前端·javascript·electron·node.js
周末不下雨11 小时前
关于搭建前端的流程整理——node.js、cnpm、vue、初始化——创建webpack、安装依赖、激活
前端·vue.js·node.js
王解12 小时前
【Webpack配置全解析】打造你的专属构建流程️(4)
前端·webpack·node.js
m0_7310482015 小时前
nodejs:下载,安装,系统环境配置,更换镜像
node.js
油丶酸萝卜别吃15 小时前
NPM镜像源
前端·npm·node.js
脱了格子衬衫19 小时前
npm/pnpm/yarn设置国内淘宝源
前端·npm·node.js
花姐夫Jun19 小时前
node.js学习笔记-快速搭建一个 Express 项目的基本骨架(一)
笔记·学习·node.js
郑小憨19 小时前
Node.js GET/POST请求、WEB模块使用介绍 (基础介绍 八)
开发语言·前端·javascript·npm·node.js
南城巷陌19 小时前
node.js实现批量修改git项目的数据源
git·node.js·修改git项目数据源