我已经使用文档列表中的所有“生产级React框架”构建过应用程序,但我也花了多年时间构建只需要客户端功能的单页面应用程序(SPAs),一切正常。...SPA存在的问题 反复出现的一个问题是“spinner-geddon”;每次您导航到一个新的“页面”时,都会显示一个加载动画来指示正在请求数据,只有在HTTP请求成功完成后,页面才会用内容进行渲染。...Vite文档在“构建你的第一个Vite项目”部分覆盖了您需要了解的一切;通过CLI提示选择,您可以在大约20秒内运行一个React应用。...浏览器需要这个巨大的JavaScript文件来运行应用程序。 每当保存一个文件时(在开发过程中会发生数十万次),打包就会发生。...使用Vite时,当一个文件被“保存”时,只有发生变化的模块会在bundle中被更新。这导致打包步骤要快得多,开发体验也更高效更愉快。
本文将向您展示如何实现自己的思维导图应用程序。 在我们开始之前,我想向您展示一下我们在本教程结束时将拥有的思维导图应用程序 React Flow是什么?...该库已被用于数据处理工具、聊天机器人构建器、机器学习、音乐合成器和其他应用程序中。 选择一个满足你需求的库可能会很困难,因为在不断发展的行业中有太多的选择。...在本教程中,您将学习如何使用React Flow创建一个基本的思维导图应用程序,该应用程序可用于头脑风暴、构思想法或可视化思维。 项目设置 让我们从搭建我们的React应用开始。...接下来,在组件文件夹中创建一个新文件, node.jsx 。...保存和加载思维导图 在基于React Flow的应用中保存和加载思维导图是一个重要的功能,允许用户保存和恢复他们的工作。这个功能提高了您的应用的可用性和价值。
我认为这也是一个有趣的项目,因为了解如何构建代码编辑器将使你了解到做这个项目需要处理哪些功能模块。我们第一个需要了解的模块是 CodeMirror。...安装成功后,node_modules\codemirror 文件夹下会有如下目录,这是我们后面要用到的: 接着,替换掉 src\index.js 文件夹的内容为如下代码: import React...Learn more: https://bit.ly/CRA-vitals reportWebVitals(); 创建了新的 React 应用程序后,让我们在命令行中 cd 到该项目的目录: cd web-code-editor...你可能会问:为什么我们需要使用 setTimeout() ? 如果我们在没有它的情况下编写它,那么每次在编辑器中按下一个键,我们的 iframe 都会更新,这通常不利于性能。...对于 iframe,另一个考虑因素是页面加载时间,因为 iframe 中加载的内容通常不受你的控制。在我们的应用程序中,这不是问题,因为我们的 iframe 内容不是外部的。
我认为这也是一个有趣的项目,因为了解如何构建代码编辑器将使你了解到做这个项目需要处理哪些功能模块。我们第一个需要了解的模块是 CodeMirror。...安装成功后,node_modules\codemirror 文件夹下会有如下目录,这是我们后面要用到的: 接着,替换掉 src\index.js 文件夹的内容为如下代码: import React...Learn more: https://bit.ly/CRA-vitals reportWebVitals(); 创建了新的 React 应用程序后,让我们在命令行中 cd 到该项目的目录: cd web-code-editor...你可能会问:为什么我们需要使用 setTimeout() ? 如果我们在没有它的情况下编写它,那么每次在编辑器中按下一个键,我们的 iframe 都会更新,这通常不利于性能。...对于 iframe,另一个考虑因素是页面加载时间,因为 iframe 中加载的内容通常不受你的控制。 在我们的应用程序中,这不是问题,因为我们的 iframe 内容不是外部的。
我们稍后会比较每个构建步骤的输出。重新构建这个应用程序,让我可以测试开发人员将一些相当标准的 React 依赖项添加到工具(包括 React Router 和 axios)中的体验。...设置 我决定以一种幼稚的方式在 esbuild 中启动一个 React 项目:npm安装 esbuild、React 和 ReactDOM。...然而,它不包括实时/热重载,所以你会发现自己在保存后要刷新浏览器,这不是一个良好的体验。 我决定使用新发布的 watch 功能.这告诉 esbuild 在每次保存源文件时重新编译代码。...即使我们每次保存文件时都要对整个应用程序进行重新编译,但在 esbuild 变慢之前,我们需要有一个相当庞大的应用程序。在我设置了这个工具之后,我从更改中得到了即时的反馈。...这意味着在第一次页面加载后,不会在编译、服务或请求导入的依赖项上浪费时间。Vite还提供了清晰的错误信息,打印出准确的代码块和行号,以排除故障。
经过几次失败的React入门尝试之后,我终于开始了解它了,我开始明白为什么我可能想使用React而不是原始的JS或jQuery。...保存文件后,你会注意到localhost:3000页面会自动编译并刷新数据。 继续并删除/src目录中的所有文件,我们将创建自己的样板文件,而不至于臃肿。...在index.js中,我引入了React,ReactDOM和CSS文件。...React中几乎所有内容都由组件组成,这些组件可以是类组件或简单组件。 大多数React应用程序都是许多小组件,所有内容都加载到主要的App组件中。组件也经常有自己的文件,因此让我们更改项目。...构建和发布一个React应用 到目前为止,我们所做的一切都在开发环境中。我们一直在进行即时的编译,热重载和更新。对于生产环境,我们将要加载静态文件 - 没有源代码。
前端开发包括大量的代码调整、保存和刷新浏览器。热重新加载帮助您消除最后一步。当有库更新时,Facebook提供codemod脚本来帮助您将代码迁移到新的api。这使得升级过程相对轻松。...Jest可以保存React组件和Redux状态生成的输出,并将其保存为序列化文件,这样您就不必自己手动生成预期的输出。Jest还具有内置的模拟、断言和测试覆盖率。一个图书馆来统治他们所有人!...在大多数情况下,使用ESLint就像调整项目文件夹中的配置文件一样简单。如果您不为ESLint编写新的规则,那么就没有什么可学习的。当错误出现时,请注意它们,并将其谷歌,以找到推荐的样式。...在复杂的项目中,代码的可维护性很重要,并且处理代码的人员会随着时间的推移而变化,向代码中添加类型带来的好处要多于坏处。...通过纱线安装包的不确定性问题。锁定文件,并确保在所有机器上的node_modules中,每个安装都得到完全相同的文件结构。纱线在您的计算机中使用了一个全局缓存目录,以前下载过的包不必重新下载。
换句话说,如果导入一张背景图片,缩小,然后删除这张图片后,图就无法放大了,因为操作按钮已经变灰色,不可使用了。 放大的唯一方法是重新导入背景图片,放大后将其删除。...这个缺陷改变了我对这个工具产生的好感,但因为在其他地方看不到此开源文件,所以把它加入了列表中。当然,成为开源软件对这个应用程序来说是件好事,因为这使它有可能成为未来流行的开源存储库列表。 3. ...它们会用橙色/红色标出严重的重渲染问题,帮助我们在开发页面时更容易的发现一些性能问题。 除非我们的目标是构建平庸的应用程序,否则为什么不试试这个在我们身边的好东西。 18. ...我不知道为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。...这让我可能会忘记其他网站只从这个链接学习 React 。因为可以在此找到大量有用的资源,这些资源肯定会帮助我们构建出色的 React 应用程序! 21.
换句话说,如果导入一张背景图片,缩小,然后删除这张图片后,图就无法放大了,因为操作按钮已经变灰色,不可使用了。 放大的唯一方法是重新导入背景图片,放大后将其删除。...这个缺陷改变了我对这个工具产生的好感,但因为在其他地方看不到此开源文件,所以把它加入了列表中。当然,成为开源软件对这个应用程序来说是件好事,因为这使它有可能成为未来流行的开源存储库列表。 3....它们会用橙色/红色标出严重的重渲染问题,帮助我们在开发页面时更容易的发现一些性能问题。 除非我们的目标是构建平庸的应用程序,否则为什么不试试这个在我们身边的好东西。 18....我不知道为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。...这让我可能会忘记其他网站只从这个链接学习 React 。因为可以在此找到大量有用的资源,这些资源肯定会帮助我们构建出色的 React 应用程序! 21.
The experiment 实验 我从 React 文档中选取了一个示例应用程序,并用本文中介绍的每个工具重新构建了它。我参与的项目是 Yogita Verma 的 Snap Shot。...重新构建这个应用程序使我能够测试开发人员在将一些非常标准的 React dependencies 引入到工具中的经验,包括 React Router 和 axios。...这告诉 esbuild 在每次保存源文件时重新编译代码。但是我们仍然需要一个服务器来查看我们保存的更改。...尽管我们每次保存文件时都会重新绑定整个应用程序,但是在 esbuild 变慢之前,我们需要有一个非常庞大的应用程序。在我设置了这个工具之后,我从更改中得到了即时的反馈。...在 Snap Shot 应用程序中,我最终得到了184KB 的源文件,这些文件会请求另外105kb 的来自 Skypack 的依赖项,这就形成了一个非常巨大的瀑布。
在React中页面重新加载时怎样保留数据?...这个问题就设计到了数据持久化, 主要的实现方式有以下几种: Redux: 将页面的数据存储在redux中,在重新加载页面时,获取Redux中的数据; data.js: 使用webpack构建的项目,可以建一个文件...,data.js,将数据保存data.js中,跳转页面后获取; sessionStorge: 在进入选择地址页面之前,componentWillUnMount的时候,将数据存储到sessionStorage...如果是在自己搭建的webpack配置的项目中使用,可能会遇到 regeneratorRuntime is not defined 的异常错误。...} )}; 复制代码 在集合中添加和删除项目时,不使用键或将索引用作键会导致奇怪的行为。
阻塞渲染 在浏览器中,阻塞渲染是指当浏览器在加载网页时遇到阻塞资源(通常是外部资源如样式表、JavaScript文件或图像等),它会停止渲染页面的过程,直到这些资源被下载、解析和执行完毕。...这种行为会导致页面加载速度变慢,用户可能会感觉到页面加载较慢或者出现空白的情况。...举例来说,如果一个网页中引用了外部的JavaScript文件,并且这个文件比较大或者加载速度较慢,浏览器会等待这个JavaScript文件下载完成后才继续渲染页面,导致页面在此过程中停滞或者出现明显的加载延迟...「资源合并与压缩」:将多个小文件合并为一个大文件,并对文件进行压缩,减少下载时间。 「延迟加载」:将不是立即需要的资源推迟加载,比如在页面滚动到特定位置或用户执行某些操作时再加载。...} ) } 现在,在state用实际数字更新后,它将触发导航的重新渲染,React 将重新渲染项目并删除那些不可见的项目。 6.
一个反复出现的问题就是“无休无止的加载器(spinner-geddon)”,每当导航到一个新的“页面”时,都会出现一个加载器动画,表示正在加载数据,只有在成功完成 HTTP 请求后,页面才会充满内容。...但是,在某些时候,所有的这些模块需要打包在一起,形成一个巨大的 JavaScript 文件。浏览器需要这个巨大的 JavaScript 文件来运行应用程序。...每当保存文件时都会进行打包(在开发过程中会发生成千上万次)。使用 Webpack 等工具,打包出的文件必须“拆除”并重建,这样才能反映出变化。...只有在打包步骤完成后,浏览器才会刷新,进而让开发人员真正看到自己的变更。 随着应用程序的发展,会有越来越多的 JavaScript 添加进来,打包的工作量也会越来越大。...有了 Vite,当文件“保存”时,打包文件中只会更新发生变化的模块。这将大大加快打包步骤,并带来更高效、更愉快的开发体验。
前言 后端开发的同学想必每天都在重复经历着修改代码、执行代码编译,等待……重启Tomcat服务,等待……最后测试发现还是有bug,然后上述流程再来一遍(我听不见) 能不能像前端开发的同学那样,修改代码保存文件后自动编译...通过IDEA左上角绿色的运行按钮启动Spring Boot应用,然后修改Java源代码文件后IDEA会自动重新编译项目,从而触发Spring Boot Devtools热部署。...(MyApp.class, args); 疑难解答 在IDEA中修改文件后报 Maven Resource Compiler: Maven project configuration required...答:请使用IDEA那个绿色的运行按钮启动Spring Boot应用。 在IDEA中修改文件后没有反应 答:请稍等数秒自然会触发重新编译和热部署的。 为什么是热部署而不是热替换呢?...为什么pom.xml文件中的spring-boot-maven-plugin要设置为独立JVM进程运行呢(true)?
现代化的前端项目,大部分都是单页应用程序,也就是我们说的 SPA ,整个应用只有一个页面,通过组件的方式,展示不同的页面内容,所有的数据通过请求服务器获取后,在进行客户端的拼装和展示;这就是目前前端框架的默认渲染逻辑...,此时返回的页面就是结构和数据都有的完整内容了,这样浏览器在展示首页数据的同时也能加载 SPA 脚本,搜索引擎的爬虫同样也能获取到对应的数据,解决 SEO 的问题;为了更好的理解这个逻辑,我画了一个流程图...,因为首次加载时,服务器会先将渲染好的静态页面返回,在静态页面中再次加载请求 SPA 脚本; 基本原理:首页内容及数据,在用户请求之前生成为静态页面,同时加入 SPA 的脚本代码引入,在浏览器渲染完成静态页面后...1:在 pages 文件夹中新建 _ app. js 文件(文件名固定) 2:在项目根目录下创建 styles 文件夹,并在其中创建 global.css 3:在 _app.js 中通过 import...props\[id].js 的形式,在项目构建时,next 会根据不同的 ID 值,生成不同的对应的 静态文件,如下代码 import React from 'react' import Axios from
当时我所有的项目都是基于 CRA 来开发的,但之后我选择转向 Next.js,主要有两大原因: 我偏爱基于文件的路由方式,因为它让我能够减少样板代码的编写。...此外,新版本还引入了 Layouts 功能,允许开发者定义多个路由共享的 UI 元素,并在每次导航时无需重新渲染,从而提高了页面加载效率。 然而,在缓存方面,新版本却变得更加……复杂。...然而,话虽如此,如果你是一名开发人员,只是希望在服务器组件中获取 URL,那么在阅读完这篇回答后,你可能还需要进一步查询五个相关问题,最后才会意识到可能需要重新构建或调整你的代码结构。...因为发送给客户端的数据量减少了,页面加载速度得以加快;由于积极的缓存策略,页面加载速度也得以提升;并且,当用户导航到新页面时,只有页面的部分内容需要重新渲染,这也进一步加快了加载速度。...在电子商务领域,页面加载速度的提升意味着更多的收入,因此,为了获得这些优势,你完全会接受使用更为复杂的框架。 然而,如果我是在为我的 SaaS 应用程序构建仪表板,我可能就不会太关心这些功能了。
因此,如果我们觉得能同时快速查看到大量选项是非常有用的,那么这个很适合我们。 一旦看到喜欢的入门项目后,我们就可以简单克隆存储库,根据开发中的应用需要进行简单修改。...Highlight Updates 是 React DevTools 的一项扩展功能,可以查看页面中的哪些组件正在不必要地重新渲染。 ?...它们会用橙色/红色标出严重的重渲染问题,帮助我们在开发页面时更容易的发现一些性能问题。 除非我们的目标是构建平庸的应用程序,否则为什么不试试这个在我们身边的好东西。 18....我不确定为什么提到这个网站的人不多,但在这个页面我发现了几乎所有我需要的信息,它快捷、方便,并不断更新,总是能为我所有的项目提供所需的结果。...我可能会忘记其他网站只从从这个链接学习 React 。因为可以在此找到大量有用的资源,这些资源肯定会帮助我们构建出色的 React 应用程序! 21.
Redux 是 React 生态系统中的革命性技术。它使我们能够在全局范围内存储不可变数据,并解决了在组件树中 prop-drilling 的问题。...我相信其中大多数都没有达成目标。有时为了前进。我们需要先退后一步。 如果我们不再在前端代码中管理后端状态,而只是将其视为需要定期更新的缓存会怎么样呢?...React Query 我已经在自己的多数个人和工作项目中使用 React Query 几个月了。这个库有一个非常简单的 API 和几个 hooks,用于管理查询(获取数据)和突变(更改数据)。...、缓存和无效化,只是加载数据并在加载时将其存储在全局存储中而已。...本文提到的这些库代表了我们在单页应用程序中管理状态的方式变革,并且是朝着正确方向迈出的一大步。我期待着看到它们能对 React 社区产生怎样的影响。
在我过去几年看过的所有前端技术中,我在尝试了 Flutter 后最为兴奋。在这篇文章中,我将讨论为什么它令我如此激动,并介绍如何尽快开始使用它。...强大的 CLI 我可以顺利轻松地启动和运行,而不会遇到很多障碍/错误 调试体验很好,开箱即用的热重新加载以及一系列关于调试技术的文档 (https://flutter.io/debugging...我将这个仓库克隆到一个文件夹中,然后在 HOME / .bashrc / HOME / .zshrc 文件中添加克隆目录路径。...你也会注意到,我们有一个 android 文件夹和一个 iOS 文件夹,我们的本地项目就在这里。...在 pubspec.yaml 文件中,你会注意到在依赖项下我们有一个单独的 flutter 依赖项,我们在这里引用它作为包: package:flutter/ 。
领取专属 10元无门槛券
手把手带您无忧上云