首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

React、TypeScript、NodeJS 和 MongoDB 搭建 Todo App

在本教程,我们将在服务器和客户端使用 TypeScript、React、NodeJS、Express 和 MongoDB 从头开始构建一个 Todo 应用程序。 我们从设计 API 开始。...编译 src 文件夹的每个 .ts 文件 include: 告诉编译器包含 src 目录和子目录的文件 exclude: 在编译时会排除数组的文件或文件夹 现在我们安装依赖项,使项目可以使用 TypeScript...yarn add express cors mongoose 我们还需要安装它们的类型作为开发依赖项,帮助 TypeScript 编译器理解这些包。...yarn add -D @types/node @types/express @types/mongoose @types/cors 现在,TypeScript 不会再对你提示错误——它将使用这些类型来定义我们刚刚安装的库...added", todo: newTodo, todos: allTodos }) } catch (error) { throw error } } addTodo() 函数接收包含用户输入数据的

17K30

Node.js 搭建一个 API 接口服务(实战)

,最后决定使用的技术栈就是 koa+typescript+mysql+mongodb来搭建项目。...Typescript 网上特别多关于“为什么要用Typescript开发”,“Typescript开发的好处和坏处”,“为什么不用Typescript开发”等等的争论和文章,有兴趣的同学也可以去说道说道哈...并且,一些用户身份信息或埋点信息可以存在mongo PM2 PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,性能监控、自动重启、负载均衡等,而且使用非常简单 项目搭建...= error; }) export default app 到了这一步,我们就已经可以启动一个简单的项目了 npm run tsc 编译ts文件 node app.js 启动项目 接下来在浏览器输入...不过这个项目除了使用mysql,也还有用到mongo,接下来看看mongodb怎么用 使用mongoose作为mongodb的中间件 // mongoose入口 import mongoose from

8.2K31
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    我为什么喜欢NestJS

    依赖注入最大的作用是代码解耦,依赖的对象根据不同的情况可以有多种实现,单元测试的时候可以在不改业务代码的情况下将依赖的对象换成 Mock 数据。...类型系统是后端开发很重要的一环,Nest是使用TypeScript实现的框架,因此原生就支持TypeScript,而且还大量使用了注解,熟悉 Spring 的朋友会感到十分亲切。...另外,Nest是基于Express实现的,需要的话可以取到底层的对象,request和response。...连接数据库 例子中使用mongoose连接和操作本地MongoDB数据库。为了更方便使用,Nest提供了@nestjs/mongoose包,对mongoose包装了一层,使其更符合Nest的使用风格。...操作数据库的步骤如下: app.module定义连接的数据库:MongooseModule.forRoot('mongodb://localhost/nest') cat.schema定义 Schema

    1.9K20

    基于 egg.js 构建 graphql api 服务

    npm run dev $ open http://localhost:7001 image.png 安装插件 @switchdog/egg-graphql 插件机制是egg的一大特色,由于我们基于 TypeScript...enable: true, package: '@switchdog/egg-graphql', }, 配置插件 通常插件都会有一些配置项,在/config/config.default.ts配置即可...// 设置为true时,以Apollo跟踪格式收集和公开跟踪数据 debug: true, // 一个布尔值,如果发生执行错误,它将打印其他调试日志记录 }, }; 在中间件开启...可以理解为 {id: 1, name: 'jack'} 项目启动 npm run dev 在浏览器输入 http://127.0.0.1:7001/graphql 出现如下界面说明已经 graphql...从MongoDB查询数据 安装 egg-mongoose yarn add egg-mongoose 配置 // config/plugin.ts exports.mongoose = { enable

    1.8K10

    react+koa2+mongodb实现留言功能(可体验)

    留言功能在社交占据很重要的作用。这里实现的留言功能,参考微信朋友圈的方式: 用户发送一个TOPIC话题,读者可以在该话题下面进行评论,也可以对该话题下的留言进行评论。...前端实现 使用技术 react ant design typescript 在上面的截图中,很明显,就是一个表单的设计,外加一个列表的展示。...后端 使用的技术: mongodb 数据库,这里我使用到了其ODM mongoose koa2 一个Node框架 pm2 进程守卫 apidoc 用来生成接口文档(如果你留意体验站点,右上角有一个...首先,我们对自己要存储的数据结构schema进行相关的定义: const mongoose = require('mongoose') const Schema = mongoose.Schema /.../ 定义留言字段 let MessageSchema = new Schema({ // 关联字段 -- 用户的id userId: { type: mongoose.Schema.Types.ObjectId

    1.1K10

    typescript 的数据类型有哪些

    一、typescript是什么 typescript 是 javascript的超集,在javascript基础上提供了更加实用的类型供开发使用; 支持ES6语法,支持面向对象编程的概念,类、接口、继承...2.类型注解:在TypeScript,可以使用类型注解来显式声明变量的类型,let num: number = 10;。而在JavaScript,不需要显式声明变量的类型,可以直接赋值。...3.语言特性:TypeScript在JavaScript的基础上增加了一些新的语言特性,类(Class)、接口(Interface)、枚举(Enum)等。...4.编译过程:TypeScript需要通过编译器将TypeScript代码转换为可执行的JavaScript代码,然后在浏览器或Node.js环境运行。...参考文献 https://www.tslang.cn/docs/handbook/basic-types.html

    14110

    何在 Vue TypeScript 项目使用 emits 事件

    让我们来看一个简单的例子,了解一下如何在Vue让组件进行通信。...然后,消息有效载荷存储在 messageFromChild 引用,该引用会自动更新模板以显示来自子组件的消息。 简单吧?这展示了你如何在Vue中使组件“相互通信”。...如何在Typescript正确地使用类型推断 使用emits的一个“缺点”是,当你发出一个自定义事件时,你不一定知道子组件会发出什么。这种不确定性可能会导致数据类型和运行时错误的潜在问题。...通过正确地为emits添加类型,你可以确保类型安全性,提高代码清晰度,并使你的Vue应用程序更易于维护。...让我们探索如何使用Vue 3的Composition API和script setup正确地使用TypeScript输入emits。

    44810

    从零到部署:用 Vue 和 Express 实现迷你全栈电商应用(二)

    在终端运行如下命令来安装: npm install -g express-generator 打开终端,输入如下命令测试是否安装成功: express --version # 4.15.5 然后输入如下命令初始化我们的...设计数据库的 Schemas 和 Models 我们要在服务器通过 mongoose 与 MongoDB 数据库进行交互,需要定义 Schema 和 Model。...const mongoose = require('mongoose'); const Schema = mongoose.Schema; const model = mongoose.model.bind...所有访问 /api/v1 及其子路径 /api/v1/xxx 都会激活 api 处理函数,在经典的 MVC 设计模式,api 也被成为 Controllers 。...我们在开头导入了我们之前定义的 ManufacturerModel,这是 Mongoose 为我们提供的操作数据库的接口,我们通过定义在 Model 上的一系列 find、findOne、updateOne

    3.1K10

    TypeScript是如何工作的

    相信大家对于如何在项目中使用 TypeScript 已经轻车熟路,本文就来探讨简单探讨一下 TypeScript 是如何工作的,以及有哪些工具帮助它实现了这个目标。...二、TypeScript 与 VSCode 当我们在 VSCode 中新建一个 TypeScript 文件并输入 TS 代码时,可以发现 VSCode 自动对代码做了高亮,甚至在类型不一致的地方,VSCode...Babel 有两种常见使用场景,一种是直接在 CLI 调用 babel 命令,另一种是将Babel 和打包工具( webpack)结合使用。...由于 babel 自身并不具备打包功能,所以直接在命令行调用 babel 命令的用处不大,本节主要讨论如何在 webpack 中使用 babel 处理 typescript。...当然,由于 babel 的单文件特性,@babel/preset-typescript 对于一些需要收集完整类型系统信息才能正确运行的 TypeScript 语言特性,支持不是很好, const enums

    5.4K30
    领券