API 路由 创建服务器 用 React 和 TypeScript 创建客户端 启动 创建 Todo 类型 从 API 获取数据 创建组件 添加 Todo 表单 展示 Todo 获取和展示数据 资源...在前面创建的 Todo 模块的帮助下,我们现在可以从 MongoDB 获取数据并返回 Todo 数组。...req 对象中获取 body,然后把他们传入 findByIdAndUpdate(),这个函数将会在数据库中找到 Todo 并且更新它。...我们还需要添加一个替代类型({}),因为初始状态是个空对象。 有了这些,我们现在可以继续下一步,展示获取的数据。...getTodos() 方法会返回 promise —— 因此,我们可以调用 then 函数并用获取到的数据更新 state,或者在发生任何错误时抛出一个错误。
我们在.env中为我们的应用程序配置端口 services/UploadFilesService.js: 这个文件中的函数用于文件上传和获取数据库中文件数据 后端项目结构 ├── README.md ├...file 上传的文件,以 FormData 的形式上传 onUploadProgress 文件上传进度条事件,监测进度条信息 getFiles: 函数用于获取存储在 Mongodb 数据库中的数据 最后将这个对象导出去...selectedFiles, 在上面的代码中 我们使用 Array.from 方法将可迭代数据转换数组形式的数据,接着使用 map 方法将文件的进度信息,名称信息存储到 _progressInfos...中 接着我们使用 map 方法调用 files 数组中的每一项,使 files 中的每一项都经过 upload 函数的处理,在 upload 函数中我们会返回上传文件请求函数 UploadService.upload...使用 Multer 捕获相关错误 返回响应 文件列表数据获取和下载 getListFiles: 函数主要是获取 photos.files,返回 url, name download(): 接收文件 name
数组中的每个值都有一个索引,每个索引在内存地址中都有一个引用。每个值都可以通过使用它们的索引来访问。数组的索引从零开始,最后一个元素的索引从数组的长度减一。...the array 获取数组中元素的索引 indexOf:检查一个项目是否存在于数组中。...join:用于连接数组的元素,我们在join方法中传入的参数会在数组中连接起来,并以字符串的形式返回。...根据经验, 可以对任何变化的值使用let ,对任何常量值使用const,对数组、对象、箭头函数和函数表达式使用。 对象 对象是键值对。key的顺序没有保留,或者没有顺序。...为了实现一个在箭头函数中接受无限数量参数的函数,我们使用扩展运算符后跟任何参数名称。 我们在函数中作为参数传递的任何东西都可以在箭头函数中作为数组访问。
:将Webpack打包功能与Express服务器的资源服务功能合并,Express通过中间件打包,并读取到内存中 3.webpackHotMiddleware:热替换 五、React的创新语法:JSX...3.style的属性值不能是字符串而必须为对象,对象中的属性名使用驼峰命名法,如font-size为fontSize 4.注释写在{}内 5.数组会自动展开所有成员,但是如果数组或迭代器中的每一项都是...,这些内部状态与React的事件系统配合就可以实现一些用户交互功能 2.Props:属性的意思,可以使用props向React组件传递数据,React组件从props中拿到数据,然后返回视图 3.context...显式的意思是,函数与外界交换数据只有一个唯一渠道——参数和返回值;函数从函数外部接受的所有输入信息都通过参数传递到该函数内部;函数输出到函数外部的所有信息都通过返回值传递到该函数外部 3.纯函数不能访问外部变量...4.map()方法返回一个由原数组中的每个元素调用一个指定方法后的返回值组成的新数组 5.every()方法用于测试数组中所有元素是否都通过了指定函数的测试 6.some()方法用于测试数组中是否至少有一项元素通过了指定函数的测试
React-router:是一个基于 React 之上的强大路由库,它可以让你向应用中快速地添加视图和数据流,同时保持页面与 URL 间的同步。...【后端】 NodeJs:使用 express 构建一个本地 HTTP server 来调试 React 项目 MongoDB: 存储用户数据和聊天数据的非关系型数据库 Express: Node的基于...没有的话 直接跳转到登录页 登录这里 对输入的用户名和密码做一下校验 然后存储到本地一个用户id 登录返回成功之后dispatch返回数据 触发reducer 将数据存储到state中 主页以及切换部分...头部和底部使用共有部分,中间的内容使用数组中循环渲染不同的Route 登录成功之后,有了redirect选项,并且我们在Login中,设置了路由的跳转 {this.props.redirectTo &...根据发收方的用户id 进行辨别和数组的循环渲染 未读消息的更新 默认每条数据的read字段 都是false,筛选聊天数据的发送对象是正在使用这个软件的用的时候,筛选出来的结果就是未读消息的数量 socket
二、实现React组件的服务端渲染 刚刚起的express服务返回的只是一个普通的html字符串,但我们讨论的是如何进行React的服务端渲染,那么怎么做呢?...part4: 异步数据的服务端渲染方案(数据注水与脱水) 一、问题引入 在平常客户端的React开发中,我们一般在组件的componentDidMount生命周期函数进行异步数据的获取。...三、数据的注水和脱水 其实目前做了这里还是存在一些细节问题的。比如当我将生命周期钩子里面的异步请求函数注释,现在页面中不会有任何的数据,但是打开网页源代码,却发现: ?...还是在Home组件中,做如下的修改: componentDidMount() { //判断当前的数据是否已经从服务端获取 //要知道,如果是首次渲染的时候就渲染了这个组件,则不会重复发请求...一般的中间层工作流是这样的:前端每次发送请求都是去请求node层的接口,然后node对于相应的前端请求做转发,用node去请求真正的后端接口获取数据,获取后再由node层做对应的数据计算等处理操作,然后返回给前端
: Function) store中的state是selector的唯一参数,可以从redux store中获取数据。 selector应该是一个纯函数,因为它潜在性地会在任意时刻执行多次。...selector可以返回任何值,不一定如mapState一样是个对象。而且这个返回值即是useSelector()的返回值。...如果在一个函数组件中调用了多次useSelector(),就会生成多个独立的对store的订阅,但是因为react的批量更新机制,当每次dispatch action时,还是只返回一个新值。...注意不要用useSelector()中的selector以整个对象的形式返回store state,因为每次返回的都是一个新对象,依据第五条的比较方式来说,肯定会重新触发更新的,造成不必要的性能浪费。...selector无法访问自身的props(这里我认为是selector内部无法获取),但是可以通过闭包或者a curried selector取得。
Ref对象,reactive返回响应式代理对象 从定义上看ref通常用于处理单值的响应式,reactive用于处理对象类型的数据响应式 两者均是用于构造响应式数据,但是ref主要解决原始值的响应式问题...}); }); 简单来说就是,重写了数组中的那些原生方法,首先获取到这个数组的ob,也就是它的Observer对象,如果有新的值,就调用observeArray继续对新的值观察变化(也就是通过target...使用Proxy 的好处是它可以完美的监听到任何方式的数据改变,唯一的缺点是兼容性的问题,因为 Proxy 是 ES6 的语法。...Object.defineProperty 本身有一定的监控到数组下标变化的能力,但是在 Vue 中,从性能/体验的性价比考虑,尤大大就弃用了这个特性。...Proxy 可以劫持整个对象,并返回一个新的对象。Proxy 不仅可以代理对象,还可以代理数组。还可以代理动态增加的属性。
React 16 向后兼容 React开发团队有强烈的意愿表示会向后兼容,如果你的代码能够在React 15中运行,那么也可以在React 16中运行,并且不会出现任何弃用警告,正如上面的代码,他可以很好地运行在...在React 16, 客户端渲染和服务端渲染允许组件的render 方法返回字符串,数值或者是一个元素数组。...然而,在React 16中,核心团队从头开始重写了服务器渲染器,并且根本没有进行任何vDOM的工作。 这意味着它可以快得多。...这些新方法不是返回一个字符串,而是返回一个可读流,一个用于发送字节流的对象的Node Stream类。...大多数Node Web框架都有一个从Writable继承的响应对象,所以通常可以将Readable传递给响应。
它会带来很多好处,例如: 零副作用 不可变的数据对象更易于创建,测试,和使用; 利于解耦; 更加利于追踪变化; 在 React 环境中,我们使用 Component 的概念来维护组件内部的状态,对状态的更改可以导致组建的重新渲染...Seamless-immutable:一个用于提供不可变 JavaScript 数据结构的库,他与普通的数组和对象向后兼容。...译注:函数组件也可以做纯组件的优化:React.memo(…) 是 React v16.6 中引入的新功能。它与 React.PureComponent 类似,它有助于控制 函数组件 的重新渲染。...当您从列表中添加或删除元素时,如果该 key 与以前相同,则 React虚拟DOM元素表示相同的组件。...即使 addStaticPath 不进行任何数据更改也会发生这种情况,因为 socialDetails 由 addStaticPath 函数返回的的数据每次都是一个新的对象 (请记住{} !
GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具。...ID: ID 标量类型表示一个唯一标识符,通常用以重新获取对象或者作为缓存中的键。 ID 类型使用和 String 一样的方式序列化;然而将其定义为 ID 意味着并不需要人类可读型。...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...在 express 中,可以很简单的使用中间件来将请求进行拦截,将没有权限的请求过滤并返回错误提示。 中间件实际上是一个函数,在接口执行之前,先拦截请求,再决定我们是否接着往下走,还是返回错误提示。...属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充: fields
后端这块是Node结合express和GraphQL做的接口,数据库用的是MySQL。 GraphQL的接口设计 我们先抛开GraphQL,就单纯的接口而言。...先定义用户实体和相应的接口,不做细节实现,访问相应的接口能返回相应的预期 定义一个全局变量(或者写进一个文件)去模仿数据库操作,返回相应的结果 结合数据库去实现细节,访问相应的接口能返回相应的预期 全局变量...Mock数据库的实现 第一步:导包 const express = require('express'); const { buildSchema } = require('graphql'); const...,然后暴露一个cmd方法,它返回一个Promise对象,是我们上面传入sql和参数的结果。...Hooks的钩子, useState使得函数组件可以像Class组件一样可以使用state, useEffect它接受两个参数,第一个是函数,第二个是一个数组,数组中的元素的变化会触发这个钩子的函数的执行
/users/:id - 安全路由,无论以任何角色都限于经过身份验证的用户,它会接受HTTP GET请求,并在授权成功后返回指定“ id”参数的用户记录。...如果将角色参数留为空白,则路由将被限制到任何经过身份验证的用户,无论角色如何。在用户控制器中使用它来限制对“获取所有用户”和“按ID获取用户”路由的访问。...成功认证后,会将user对象附加到包含JWT令牌中数据的req对象,在这种情况下,该对象包括用户ID(req.user.sub)和用户角色(req.user.role)。...Node.js Auth用户服务 路径:/users/user.service.js 用户服务包含用于验证用户凭据并返回JWT令牌的方法,用于在应用程序中获取所有用户的方法以及用于通过id获取单个用户的方法...我在示例中对用户数组进行了硬编码,以使其始终专注于身份验证和基于角色的授权,但是在生产应用程序中,建议使用哈希密码将用户记录存储在数据库中。
3000; // 用于存储待办事项的数组(在实际应用中,你会使用数据库) let todos = [ { id: 1, text: '学习Express' }, { id: 2,...text: '阅读文档' }, { id: 3, text: '编写代码' } ]; // 中间件:解析JSON数据 app.use(express.json()); // 获取所有待办事项...(req.params.id); // 从URL参数中获取待办事项的ID const index = todos.findIndex(todo => todo.id === todoId); //...== -1) { todos.splice(index, 1); // 从数组中删除待办事项 res.sendStatus(204); // 返回无内容状态码 } else {...返回状态码来指示操作的结果,如使用res.sendStatus(204)来指示成功删除了资源但没有返回任何内容。
虽然像 react-charts 这样的包要求以对象结构的方式提供数据,但 react-charts 的实现要求以键分组的格式提供数据,所以我看到大多数开发人员使用 .forEach() 方法或错误地使用...不使用上述任何方法,一个相当干净和易读的方法是使用数组的reduce方法,上述代码现已得到修正。...// 输出按用户ID分组的待办事项数据 console.log(todosForUserMap); }) 这样做不会创建任何不必要的数组,更加简洁,更好使用。...在数据获取的场景中,数据库或 API 中的数据可能是无限的,且数量庞大,你需要在前端进行流式处理。在这种情况下,React 中最常用的解决方案是无限加载方案。...const itr = fetchProducts(); // 调用fetchProducts()函数以获取产品数据的生成器对象 // 这应该根据用户交互或其他策略来调用 // 避免无限加载数据
复杂,行多,使用传统 1.2. promise 解决异步回调多层嵌套的问题 是一个容器; 包含某个未来结束的事件 是一个对象: 从它可获取异步操作的消息 pending 进行中 resolved...Promise.race 它同样接收一个数组,不同的是只要该数组中的 Promise 对象的状态发生变化(无论是 resolve 还是 reject)该方法都会返回 async/await async...方法,从停止地方开始执行,移向下一个状态 1.5. yield 与 return 相似:都能返回紧跟在语句后面那个表达式的值 区别:记忆功能,执行次数,返回值数量 1.6....一个参数时,返回该参数 参数不是对象,转成对象(undefined,null会报错),若为源对象位置,则跳过 可用来操作数组,将数组视为对象 浅拷贝非深拷贝(若源对象的有对象属性值,则拷贝的是该引用)...外部无法访问 实现面向对象中的对象 这样不同的对象(类的实例)拥有独立的成员及状态,互不干涉 优点: 可以让一个变量常驻内存 (如果用的多了就成了缺点 避免全局变量的污染 私有化变量 缺点: 因为闭包会携带包含它的函数的作用域
你也可以 在众多app中来挑选,但是这些日子我开始使用React做项目,所以我将会选择React来做前端框架。不过,你也可以挑选你用得习惯的任何js框架。...这背后的原因是每次我们都启动服务,在内存中存储的Todo(s)数组变为空了。我们将在下面的内容中展示如何向数组中添加数据。 如你所见,返回的格式已经被替换成了客户端已经定义和描述过了的查询格式。...GraphQL的查询都像是没有属性的JSON对象,GraphQL 不是一种语言特性 这点被提到 很重要,它只是在客户端和服务端中间的一种规范。如果使用通用的语言,任何的客户端都能和任何服务端通信。...如果你需要一个React指南,你可以阅读下面的资料: 视频: React入门 React JS库概述 视频: 单向数据流概述 一个简单的React 组件 React 组件通过render()方法来获取输入数据并将返回结果渲染展示...所以我们每次重启服务,在内存中的存储了todo(s) 数组数据都会被清空。当然 ,我们不单单想只读空数组,我们还需要添加和更新数据。
在这篇教程中,我们将通过 API 获取数据的方式制作一个简单的通讯录应用。我们会使用 Express (NodeJS)服务器发送数据,需要说明的是并不一定非要使用 Node。...服务器 项目开始之前先创建 Express 服务器,保证 React 应用程序可以获取数据。...在 /api/contacts 端口,我们使用 map 方法获取数组中对象的 id 和 name 字段。...而在 /api/contacts/:id 端口,我们通过特殊的 id 字段检索数组并获得对应的对象。为了简单起见,我们只是使用模拟数据。在真实的应用中,这些数据是从服务器返回的。...排除操作在 actions 的 catch 方法中。另外,我们可以 resolve (处理)从 API 获取的数据。
/目录"")); 3.9.4.重定向 res.redirect( ""/"" ); 3.9.5.获取前台传递数据 3.9.5.1.get请求:req.query 返回处理后的对象吧 3.9.5.2.post...async.parallel({函数对象集合},所有函数执行完之后的回调函数(err,result){}) 4.前后数据交互 4.1.获取数据 4.1.1.前数据在requestd对象中,通过操作该对象获取数据....需要监听数据传输 4.1.3.2.第一步:注册数据传输事件,并将数据片段存储到数组中 var temp = []; req.on(""data"",function( v ){ temp.push(...( temp ).tostring(); }) 4.2.返回数据 4.2.1.通过response对象的end()方法返回 5.mongodb 5.1.介绍 5.1.1.MongoDB是一个跨平台,面向文档的数据库...,高性能,高可用性和易于扩展 5.1.2.mongo中的数据库:是一个集合的物理容器,一个单一的MongoDB服务器通常有多个数据库。
领取专属 10元无门槛券
手把手带您无忧上云