最近开始学习NestJs这个框架。学习成本比其他框架相对高了很多。
其注册配置相对复杂一开始学起来有点摸不着哪跟哪;但这也是相比其他框架更规范严谨的体现。保证了大型项目的稳定健壮的使用!
在学习node基础框架Express和Koa的时候。对数据库的操作一直都是以编写SQL语句实现。需要什么编写什么。这样显得非常死板也不灵活。后来了解到NestJs是OOP思想编程(NestJs可以使用TypeScript也是OOP思想)才知道原来对数据库的操作可以用对象形式体现。在数据库中每一个表(Schema)都可以看作Nest框架中的一个对象。这样在对数据库操作就显得非常灵活
例如:(这是随便一个表的结构)
它可以看做成NestJs中的一个对象
这样一来对数据库中每个表的操作就显得非常简单了。
这里我们拿链接mongoDB操作来举例
根据官方文档使用mongoose
首先是安装所需依赖
npm install --save @nestjs/mongoose mongoose
可以加个淘宝镜像:
–registry=https://registry.npm.taobao.org
这个已经打的很熟练了用起来很方便。下载速度会相对快很多
安装完成后我们到app.module.ts中添加配置
app.module.ts
在imports:[]中添加相应配置
MongooseModule.forRoot(‘mongodb://localhost/test') //后面是MongoDB的位置(根据需要而定) 对应添加相应依赖 import { Module } from ‘@nestjs/common'; import { MongooseModule } from ‘@nestjs/mongoose';
这个时候保存后在控制台就可以看到
DeprecationWarning: current URL string parser is deprecated, and will be removed in a future version. To use the new parser, pass option { useNewUrlParser: true } to MongoClient.connect
这么类似的一句话。就说明链接成功了
接着对模型注入(Schema)
在你相应的模块文件夹里创建schema文件夹。创建xx.schema.ts
例如我的是users/schemas/users.schema.ts
import * as mongoose from 'mongoose' export const UserSchema = new mongoose.Schema( { id: Number, name: String, introduction: String, headurl: String, bigurl: String, username: String, password: String, }, { collection: 'musicers', versionKey: false }, )
对应的是上图的表结构(collection:可以看作MongoDB中的一个表。)
接下来在相对应的users.module.ts模块进行配置添加
import { Module } from '@nestjs/common'; import { MongooseModule, getModelToken } from '@nestjs/mongoose'; import { UsersController } from './users.controller'; import { UsersService } from './services/users.service'; import { UserSchema } from './schemas/users.schemas'; @Module({ imports: [ //这里添加配置。对应引入模块(注意里面的括号结构别给坑了。这里我卡了半天) MongooseModule.forFeature([ { name: 'User', schema: UserSchema } ]) ], controllers: [UsersController], providers: [ UsersService, ], }) export class UsersModule {}
这么配置好后。我们就可以在service端操作了
service端 => users/users.service.ts
咋们就拿一个查找来测试
import { Model } from 'mongoose'; import { Injectable } from '@nestjs/common'; import { InjectModel } from '@nestjs/mongoose'; import { User } from '../interface/users.interface'; import { IUserService } from '../interface/user-service.interface'; @Injectable() export class UsersService implements IUserService { constructor(@InjectModel('User') private readonly userModel: Model<User>) {} private static users:User[] = [ ] async findAll():Promise<User[]>{ //return UsersService.users return await this.userModel.find({}) //( 这里我们测试查找全部 ) } }
controller端 => users/users.controller.ts
@Controller('users') export class UsersController { constructor(private readonly userservice: UsersService) { } @Get('getall') // @UseGuards(AuthGuard('jwt')) async findAll():Promise<User[]> { return await this.userservice.findAll() } }
我们开一个接口出来
这里的3001是在main.ts中自定的。根据自己情况更改
然后我们可以访问
http://localhost:3001/users/getall
得到了结果
输出完成。其他操作也是根据类似的步骤进行
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。