跳至主要內容

nodejs框架技术选型

Mr.Dylin...大约 5 分钟8.node&服务器端

nodejs框架技术选型

NodeJS 的 Web 框架有很多,目前常见的主要包括 ExpressJS、KoaJS、NestJS、MidwayJS 等,我们做个简单介绍,做个简单的对比。

Express(59K Stars)

基本介绍

Expressopen in new window 是 NodeJS 早期率先出现的一款框架,现在仍然非常流行,包括前端本地开发常用的 WebpackDevServer,底层就是基于它实现的。

核心特性

Express 是基于函数回调实现异步的,采用 Node 中最常见的 Error-First 的模式设计的,和 NodeJS 本身设计非常相似,非常经典。 同时内置许多常用中间件,可谓是大而全,让人省心。

HelloWorld 示例

const express = require('express');
const app = express();

// 中间件
app.use((req, res, next) => {
  next();
});

// 路由
const router = express.Router();
router.get('/hello', (req, res) => {
    res.send('Hello World!');
});
app.use(router);

// 静态资源访问
app.use(express.static('./static'));

// 端口监听
app.listen(3000);

Koa2(33K Stars)

基本介绍

随着 ECMAScript 的发展,Async Functions(ES2017)同步方式写异步代码的方式开始流行, KoaJSopen in new window 一个新的 web 框架,由 Express 原班人马打造,诞生了。

核心特性

Koa2 基于 Async Functions 实现,而使用 Try-Catch 来捕获错误。

Koa2 更关注框架本身性能体积以及定制扩展性,可谓是小而精。而对于后端开发常用的 session,视图模板,路由,文件上传,日志管理等方案,更多由社区提供。

HelloWorld 示例

const Koa = require('koa');
const Router = require('koa-router');
const serve = require('koa-static');
const app = new Koa();

// 中间件
app.use(async (ctx, next) => {
  await next();
});

// 路由
const router = Router();
router.get('/hello', (ctx) => {
    ctx.body = 'Hello World!';
});
app.use(router.routes());

// 静态资源访问
app.use(serve('./static'));

// 端口监听
app.listen(3000);

NestJS(33K Stars)

基本介绍

不同于前两者,NestJS 是一套成体系的 NodeJS 后端开发框架。

核心特性

  • 采用 TypeScript(JS 的超集语言) 提供优秀的类型支持
  • 底层平台依赖无关,默认基于 Express 框架实现,可以使用 Express 提供的 API、对象等;同时通过底层 API 适配器,底层也可以替换成其它平台,比如 fastify、http://socket.ioopen in new window 等(目前已官方支持,但好像还不支持 koa)
  • 装饰器路由,基于装饰器实现某个 API 的定义,包括路径、请求方法、入参等快速定义,实现路由去中心化
  • 支持依赖注入,通过装饰器声明快速实现 Service 依赖注入进其它 Service 或者 Controller 中

HelloWorld 示例

使用 Nestjs 开发 Rest API,主要围绕着以下三个东西:

  • Controller 控制器,主要负责路由验证和管理;
  • Service 服务,主要负责数据库 CRUD 逻辑的封装编写;
  • Module 模块,主要负责整合 controllers 和 Service,也可以导出给其它模块复用。

大致目录结构和写法如下:

// app.controller.ts    ****************************
import { Controller, Get } from "@nestjs/common";
import { AppService } from './app.service';

// 路由
@Controller("/")
export class AppController {
  constructor(private readonly appService: AppService) {}

  @Get("hello")
  getHello() {
    return this.appService.getHello();
  }
}


// app.service.ts    ****************************
import { Injectable } from "@nestjs/common";

@Injectable()
export class AppService {
  async getHello(): string {
    return "Hello World!";
  }
}


// app.module.ts    ****************************
import { Module } from '@nestjs/common';
import { ServeStaticModule } from '@nestjs/serve-static';
import { AppController } from './app.controller';
import { AppService } from './app.service';

@Module({
 imports: [
   // 静态资源访问
   ServeStaticModule.forRoot({ rootPath: './static' }),
  ],
  controllers: [ AppController ],
  components: [ AppService ],
})
export class appModule {}


// main.ts(约定:src根目录下且必须该文件命名)    ****************************
const app = await NestFactory.create(AppModule);
// 端口监听
app.listen(9000);

Midway(6K Stars)

基本介绍

Midway 是阿里推出的一款基于渐进式理念研发的 Node.js 框架。

核心特性

其设计方向上应该是和 NestJS 对标的,包括 TS、装饰器路由、依赖注入等基本特性基本都支持。

不一样的是,Midway 底层默认依赖的 Koa,而不是 Express。

HelloWorld 示例

使用 Midway 开发 Rest API,使用方式和 NestJS 大同小异。

但有点儿不一样的是,你无需声明 Modules 模块整合 ControllersServices,然后在根 AppModule imports 声明。

在 Midway 中,你只需要在项目内 Controller 控制器实现的地方声明 @Controller("/xxx"),最终路由 /xxx 即可生效,这点还是比较方便的。

大致目录结构和写法如下:

// app.controller.ts    ****************************
import { Controller, Get, Inject } from "@midwayjs/decorator";
import { AppService } from './app.service';

// 路由
@Controller("/")
export class AppController {
  @Inject()
  appService: AppService;

  @Get("/hello")
  getHello() {
    return this.appService.getHello();
  }
}


// app.service.ts    ****************************
import { Provide } from "@midwayjs/decorator";

@Provide()
export class AppService {
  async getHello(): string {
    return "Hello World!";
  }
}


// configuration.ts(约定:src根目录下且必须该文件命名)    ****************************
import { App, Configuration } from '@midwayjs/decorator';  
import { ILifeCycle } from '@midwayjs/core';  
import * as koa from '@midwayjs/koa';

@Configuration({  
imports: [koa],  
importConfigs: ['./config/config.default')],  
})  
export class ContainerLifeCycle implements ILifeCycle {
  async onReady() {}
}


// config/config.default.ts    ****************************
import { MidwayAppInfo } from '@midwayjs/core'

export default (appInfo: MidwayAppInfo) => {
  koa: {
    // 端口监听
    port: 9000,
  }
}

NextJS和NuxtJS

NextJS和NuxtJS放到一起说,这两个框架主要用于react和vue项目的ssr渲染。

服务器端渲染(ssr):可以极大地提高页面的加载速度和SEO效果。

  • NextJS是一个基于React的前端开发框架,它提供了完整的SSR支持,包括路由、数据获取和代码拆分等功能。
  • NuxtJS是一个基于Vue.js的服务端渲染框架,它同样提供了SSR以及其他高级功能,如状态管理、中间件和API路由等。

总结和对比

ExpressJS、KoaJS属于基础框架,使用于临时开发、demo、和基础。

NestJS、MidwayJSWeb 服务端开发和工作开发使用

NestJS、MidwayJS两者能力和使用方式上大同小异,所以选谁都可以。由于底层依赖框架不同(虽然很少能感知到底层),那么,熟悉 KoaJS 的可以尝试 MidwayJS,熟悉 Express 可以尝试 NestJS

上次编辑于:
贡献者: zddbic