Nest:配置静态资源和模块引擎

Nest 配置静态资源

在根目录新建 public 目录,然后在 images 目录保存一个图片,比如 pic1.jpg:

这样就可以通过 http://localhost:3000/images/pic1.jpg 来访问图片了。

我们也可以配置虚拟目录,比如我们想通过 http://localhost:3000/static/images/pic1.jpg 来访问 public 目录里面的文件,这样写:

Nest 配置模版引擎

  1. 安装对应的模板引擎 比如 ejs
bash 复制代码
npm i ejs -D
  1. 配置模版引擎:
  1. 项目根目录新建 views 目录然后新建 index.ejs
  1. 使用创建的 ejs 文件渲染页面
  1. 访问页面

Nest 模板引擎结合 Post 表单演示

创建 UserControll:

如果忘记如何创建的命令,输入 nest g --help 可查看帮助:

自动帮我们生成了文件并导入到 AppModule 根模块:

创建 user.ejs:

内容如下

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <title>Document</title>
  </head>
  <body>
    <form action="/user/doAdd" method="post">
      <input type="text" name="username" placeholder="请输入用户名" />
      <br />
      <input type="text" name="age" placeholder="年龄" />
      <br />
      <input type="submit" value="提交" />
    </form>
  </body>
</html>

UserController 内容如下:

typescript 复制代码
import { Controller, Get, Post, Body, Response, Render } from '@nestjs/common';

@Controller('user')
export class UserController {
  @Get()
  @Render('default/user')
  index() {
    return { name: '张三' };
  }

  @Post('doAdd')
  doAdd(@Body() body, @Response() res) {
    console.log(body);
    res.redirect('/user'); //路由跳转
  }
}

访问页面:

输入内容提交:

此时 form 表单会提交 POST 请求,路径是 /user/doAdd,命中我们的 UserController 路由

会打印 body 然后重定向页面到 user:

相关推荐
水银嘻嘻4 小时前
12 web 自动化之基于关键字+数据驱动-反射自动化框架搭建
运维·前端·自动化
小嘟嚷ovo4 小时前
h5,原生html,echarts关系网实现
前端·html·echarts
十一吖i5 小时前
Vue3项目使用ElDrawer后select方法不生效
前端
只可远观5 小时前
Flutter目录结构介绍、入口、Widget、Center组件、Text组件、MaterialApp组件、Scaffold组件
前端·flutter
周胡杰5 小时前
组件导航 (HMRouter)+flutter项目搭建-混合开发+分栏效果
前端·flutter·华为·harmonyos·鸿蒙·鸿蒙系统
敲代码的小吉米5 小时前
前端上传el-upload、原生input本地文件pdf格式(纯前端预览本地文件不走后端接口)
前端·javascript·pdf·状态模式
是千千千熠啊5 小时前
vue使用Fabric和pdfjs完成合同签章及批注
前端·vue.js
九月TTS6 小时前
TTS-Web-Vue系列:组件逻辑分离与模块化重构
前端·vue.js·重构
我是大头鸟6 小时前
SpringMVC 内容协商处理
前端
Humbunklung6 小时前
Visual Studio 2022 中添加“高级保存选项”及解决编码问题
前端·c++·webview·visual studio