首页
学习
活动
专区
圈层
工具
发布

为什么我不再用Redux了

现在,前端开发中的很大一部分负担来自于我们的全局存储的维护工作,我们还要确保这些存储不会遭受状态错误、数据非规范化和陈旧数据的困扰。...Redux 不是缓存 使用 Redux 和类似的状态管理库时,大多数人都会遇到的一大问题是,我们会将其视为后端状态的缓存。...后端状态的更简单方法 我认为有两个库比使用 Redux(或类似的状态管理库)存储后端状态要好用很多。...、缓存和无效化,只是加载数据并在加载时将其存储在全局存储中而已。...只要函数是异步的,实现就无关紧要——你可以轻松地使用 Fetch API 代替 Axios。 要更改后端状态时,React Query 提供了 useMutation hook。

3.1K20

美团前端react面试题汇总

/actionTypes'import axios from 'axios'function* func(){ try{ // 可以获取异步返回数据 const res...存储全局数据时,会有一个问题,如果用户刷新了网页,那么通过redux存储的全局数据就会被全部清空,比如登录信息等。...这时就会有全局数据持久化存储的需求。首先想到的就是localStorage,localStorage是没有时间限制的数据存储,可以通过它来实现数据的持久化存储。...但是在已经使用redux来管理和存储全局数据的基础上,再去使用localStorage来读写数据,这样不仅是工作量巨大,还容易出错。那么有没有结合redux来达到持久数据存储功能的框架呢?...实现React持久化本地数据存储的简单应用。

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

    前端高频react面试题

    如何解决 props 层级过深的问题使用Context API:提供一种组件之间的状态共享,而不必通过显式组件树逐层传递props;使用Redux等状态库。React Hook 的使用限制有哪些?...状态管理器和变量挂载到 window 中有什么区别两者都是存储数据以供后期使用。...这个问题就设计到了数据持久化, 主要的实现方式有以下几种:Redux: 将页面的数据存储在redux中,在重新加载页面时,获取Redux中的数据;data.js: 使用webpack构建的项目,可以建一个文件...中,每次进入页面判断sessionStorage中有没有存储的那个值,有,则读取渲染数据;没有,则说明数据是初始化的状态。...返回或进入除了选择地址以外的页面,清掉存储的sessionStorage,保证下次进入是初始化的数据history API: History API 的 pushState 函数可以给历史记录关联一个任意的可序列化

    4K20

    我是这样在 React 中实践 TDD 编程的

    基本上,使用Redux,我们想执行CRUD操作。...用户可以: 创建用户 更新用户 删除用户 获取用户或用户列表 这个小项目中的用户将有四个属性: id\name\username\email 为了简单起见,我们不编写UI代码。...准备好mock适配器后,我们就可以专注于初始化存储和并编写测试了。 编写测试 这是最有趣的部分。让我们开始TDD。 首先,让我们创建并配置存储。在src目录中,创建一个名为index.js的新目录。...在这个文件中,初始化存储。...我们刚刚使用Redux、thunk和axios mock编写了一些测试 对你来说有点挑战吗?添加诸如删除用户、修改以及检索用户等功能。 结论 在本文中,我们快速介绍了使用Redux的TDD。

    2.7K30

    2022社招React面试题 附答案

    它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。通过自定义hook,可以复用代码逻辑。...实例: 一个实例instance是你在所写的组件类component class中使用关键字this所指向的东西(译注:组件实例)。它用来存储本地状态和响应生命周期事件很有用。.../actionTypes'import axios from 'axios'function* func(){ try{ // 可以获取异步返回数据 const res...Redux 状态管理器和变量挂载到 window 中有什么区别 两者都是存储数据以供后期使用。...这些 state 可能包括服务器响应、缓存数据、本地生成尚未持久化到服务器的数据,也包括 UI状态,如激活的路由,被选中的标签,是否显示加载动效或者分页器等等。 管理不断变化的 state 非常困难。

    2.4K50

    2021高频前端面试题汇总之React篇

    它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性。通过自定义hook,可以复用代码逻辑。...实例: 一个实例instance是你在所写的组件类component class中使用关键字this所指向的东西(译注:组件实例)。它用来存储本地状态和响应生命周期事件很有用。.../actionTypes' import axios from 'axios' function* func(){ try{ // 可以获取异步返回数据 const...Redux 状态管理器和变量挂载到 window 中有什么区别 两者都是存储数据以供后期使用。...这些 state 可能包括服务器响应、缓存数据、本地生成尚未持久化到服务器的数据,也包括 UI状态,如激活的路由,被选中的标签,是否显示加载动效或者分页器等等。 管理不断变化的 state 非常困难。

    2.5K00

    (译) 如何使用 React hooks 获取 api 接口数据

    如果你想查看完整的如何使用 React Hooks 获取数据的项目代码,可以查看 github 的仓库 如果你只是想用 React Hooks 进行数据的获取,直接 npm i use-data-api...这里我们使用 axios 来获取数据,当然,你也可以使用别的开源库。...毕竟,我们只有三个状态转换:初始化提取过程,通知成功的数据提取结果,并通知错误的数据提取结果。 在我们自定义的 hook 中,state 像以前一样返回。但是因为我们有一个状态对象而不是独立状态。...注意:实际上不会中止数据获取 - 这可以通过Axios Cancellation实现 - 但是对于 unmounted 的组件不再执行状态转换。...由于Axios Cancellation在我看来并不是最好的API,因此这个防止设置状态的布尔标志也能完成这项工作。 完

    30K20

    【微信小程序】---- redux 在原生微信小程序的使用实例

    weapp-redux 下载 weapp-redux 使用实例下载 预览 开发 1. 目标 学会 redux 在原生微信小程序的使用; 学习和思考微信小程序中封装 Provider; 2....; 在订阅方法中获取当前页面需要订阅的全局状态,收集; 由于微信小程序的逻辑层和视图层通信需要使用 setData 函数,但是调用太频繁,消耗性能,因此收集需要订阅的全局状态,统一将数据通知视图层。...订阅生成,但是如果不取消,就会一直存在,在修改全局状态时,会执行 listeners 中所有的订阅。但是页面卸载后下次进入就会生成新的 id,新的页面,所以需要重新订阅。...思考: 由于订阅后,派发时所有收集订阅都会执行,是否可以标记订阅,仅通知当前修改的全局状态存在的订阅,不存在当前修改状态的订阅不派发? setData 可以只更新部分修改的变量,不修改全部的变量。...总结 由于性能的原因,能够不使用,就尽量不使用; 除非多页面多组件同时使用了该全局状态,同时业务逻辑比较复杂,容易混淆,使用全局状态方便管理,否则不要设置为全局状态; 在订阅优化尽量只执行更新的订阅;

    6.2K10

    一文入门react全家桶

    UNSAFE_前缀才能使用,以后可能会被彻底废弃,不建议使用。...常用的ajax请求库 1.jQuery: 比较重, 如果需要另外引入不建议使用 2.axios: 轻量级, 建议使用 1)封装XmlHttpRequest对象的ajax promise风格 3)可以用在浏览器端和...文档 https://github.com/axios/axios 4.2.2. 相关API 1)GET请求 axios.get('/user?...什么情况下需要使用redux 1.某个组件的状态,需要让其他组件可以随时拿到(共享)。 2.一个组件需要改变另一个组件的状态(通信)。 3.总体原则:能不用就不用, 如果不用比较吃力才考虑使用。...通过props接收数据(一般数据和函数) 3)不使用任何 Redux 的 API 4)一般保存在components文件夹下 2.容器组件 1)负责管理数据和业务逻辑,不负责UI的呈现 2)使用 Redux

    3.9K20

    使用 React 和 Django REST Framework 构建你的网站

    在我们最近的工作中,构建网站使用的架构是带有 Django REST Framework(DRF)后端的 React 前端。它们是通过在前端使用 axios(前端库)调用后端 API 来交互的。...我们还使用了 Redux(前端库)来存储全局的应用程序状态(存在浏览器端)。这是我们首选,因为它允许前后端完全分离。...redux-logger redux-persist react-redux $ npm install --save axios react-router-dom lodash 现在,我们先只展示将前端连接后端的主要部分...一旦完成,我们就可以使用我们存储的 token 令牌来创建一个基于 axios 的 API 客户端(译者注:这样就不需要每次都显式的将令牌信息从 store 中拿出来再插入 payload 中了),这样从我们的...你现在可以尝试使用 Auth.js 登录功能来获取我们之前创建的用户身份验令牌。

    7.8K70

    使用React Query做为axios请求库的上层封装

    前言 在项目中,通常都需要跟服务端进行异步的数据交互,基本都是用到axios这个库来做请求,嗯,毕竟拥有80k star,明星项目 接下来,我们来回顾下axios在项目中的使用 以查询用户信息为例,我们会这样封装...async function requestUsers(){ const {data} =await axios.get('/api/users'); return data; } 我们再用...另外,现在的前端项目特别是单页面应用,会使用Flux、Redux、Mobox等状态管理库,会把组件间共享的数据都存放在状态管理库中,这些可以分为两类,一类是用户交互的中间状态,比如isLoading,isClose...,它使 React 程序中的获取,缓存,同步和更新服务器状态变得轻而易举。...解决了什么问题 服务端状态有以下特点: 存储在远端,本地无法直接控制 需要异步 API 来查询和更新 可能在不知情的情况下,被另一个请求方更改了数据,导致数据不同步 现有的状态管理库(如 Mobx、Redux

    2.7K30

    放弃Redux吧,转投Zustand吧

    它提供了一种简单的 API,使得开发者能够轻松地在应用程序中的任何地方访问和修改状态。 使用 Zustand,开发者可以通过创建一个 store 来存储和管理应用程序的状态。...开发者可以使用 useStore 钩子来获取和更新状态,而不需要通过多层的组件传递 props 或者使用 React Context。 6....: [], // 不持久化任何状态 debug: false, // 是否在控制台输出调试信息 } ) ) // 现在你可以在组件中使用 useSettingsStore 钩子来访问和修改状态...自定义持久化中间件 如果你需要更细粒度的控制或者想要创建自己的持久化逻辑,你可以通过创建自定义中间件来实现。例如,你可以创建一个中间件来处理特定的存储逻辑或者在持久化前后执行额外的操作。...// 状态和操作 }) ) ) 通过使用 Zustand 的持久化插件,你可以轻松地将状态保存在客户端存储中,从而提供更好的用户体验和更健壮的应用程序状态管理。

    97110

    万万没想到react请求数据花样如此之多

    说来说去,说简单点,一个web应用,应该是状态驱动的,而状态=数据+逻辑所以,我们的UI=Render(Data+Logic) 那么,Data从何而来,可以说99%的web应用的Data是从网络而已,俗称网络获取数据...下面的代码段是一个很简单的显示列表数据模板,很简单,这里只用到了useState这个Hook,如果需要填充数据,很明显,使用setData给到数据就可以了,数据从何而来,这是一个问题,带到今天来看,要讲的是如何从网络获取数据...{ const result = await axios( 'https://hn.algolia.com/api/v1/search?...复用性无话可说,方便做备忘录,使用一个history数组记录每次变更的state就OK啦。anymore,自己YY吧。...最后,你可能会想,页面componentWillUnmount时,如果网络请求没回,是不是该”终止网络请求“ const useDataApi = (initialUrl, initialData) =

    1.5K81
    领券