掘金 后端 ( ) • 2024-04-03 13:37

视频教程

06_nest控制器和参数获取1_哔哩哔哩_bilibili

nest new argument -p pnpm
nest g resource person
pnpm start:dev

测试下:http://localhost:3000/person/1

在浏览器中看到图中的内容就是成功了

1. 路由

在Nest.js中,路由是由@Controller装饰器定义的控制器类和各种HTTP方法装饰器组合而成的。Nest.js支持常见的HTTP方法,如GET、POST、PUT、DELETE、PATCH等,并通过装饰器来声明对应的方法。

1.1. hello world是怎么出现的

打开 src 下的 main.ts,可以看到下面的代码

这里的3000,就是为什么我们要在浏览器中必须写3000的原因

我们在来看看src 下的 app.service.ts

找到了Hello World,那么在哪调用它的呢

打开 srcapp.controller.ts

这里引入了 app.service.tsAppService 类,并且实例化,然后通过 @Get 修饰AppController 类 里面的getHello() 方法,表示这个方法会被GET请求调用

1.2. 局部路由前缀

还记得最开始让大家在浏览器输入的http://localhost:3000/person/1这个路径吧。上图@Controller('person'),就代表了为什么我们要加person这个前缀,那我们是为什么还要加 /1 这个呢?等我们马上讲参数获取,大家就明白了。

1.3. 全局路由前缀

这个是在 main.ts 中设置,加上app.setGlobalPrefix()

2. url param(路径参数)

http://localhost:3000/person/1

这里的 1 就是路径中的参数

nest中声明与获取方式

我们还可以在获取的时候不指明属性

Nest 里通过 :参数名 的方式来声明(比如上面的 :id),然后通过 @Param(参数名) 的装饰器取出来注入到 controller。

@Controller('person') 的路由和 @Get(':id') 的路由会拼到一起,也就是只有 /person/xxx 的 get 请求才会走到这个方法。

3. query参数

通过 url 中 ?后面的用 & 分隔的字符串传递数据。比如:

http://localhost:3000/person/find?name=xt&age=18

这里的 name 和 age 就是 query 传递的数据。

nest中声明与获取方式

同理 这里我们一样可以不指明

注意,这个 find 的路由要放到 :id 的路由前面,因为 Nest 是从上往下匹配的,如果放在后面,那就匹配到 :id 的路由了

4. form urlencoded

直接用 form 表单提交数据就是这种,它和 query 字符串的方式的区别只是放在了 body 里,然后指定下 content-type 是 application/x-www-form-urlencoded。

Nest,使用 @Body 装饰器,Nest 会解析请求体,然后注入到 dto 中(dto 是 data transfer object,就是用于封装传输的数据的对象)

这里也可以指明要取得值,不在演示。

这里是post请求,我们不能再通过浏览器触发了,我这里使用的是apifox触发

5. json

我们代码不需要做改动,只需要在发送请求时,改变一下content type,Nest 内部会根据 content type 做区分,使用不同的解析方式

6. form data

form data 是用 -------- 作为 boundary 分隔传输的内容的

Nest 解析 form data 使用 FilesInterceptor 的拦截器,用 @UseInterceptors 装饰器启用,然后通过 @UploadedFiles 来取。非文件的内容,同样是通过 @Body 来取,@UploadedFile等后面讲文件上传在给大家演示

7. 其他的

nestjs 提供了方法参数装饰器 用来帮助我们快速获取参数 如下

@Request() req @Response() res @Next() next @Session() req.session @Param(key?: string) req.params/req.params[key] @Body(key?: string) req.body/req.body[key] @Query(key?: string) req.query/req.query[key] @Headers(name?: string) req.headers/req.headers[name] @HttpCode