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

你要的 React 面试知识点,都在这了

) 什么是 Context 什么是 Hooks 如何提高性能 如何在重新加载页面时保留数据 如何从React中调用API 总结 什么是声明式编程 声明式编程是一种编程范式,它关注的是你要做什么,而不是如何做...在组件接收到新的props或者state时被调用。在初始化时或者使用forceUpdate时不被调用。 可以在你确认不需要更新组件时使用。...在显示列表或表格时始终使用 Keys,这会让 React 的更新速度更快 代码分离是将代码插入到单独的文件中,只加载模块或部分所需的文件的技术。...如何在重新加载页面时保留数据 单页应用程序首先在DOM中加载index.html,然后在用户浏览页面时加载内容,或者从同一index.html中的后端API获取任何数据。...如果通过点击浏览器中的重新加载按钮重新加载页面index.html,整个React应用程序将重新加载,我们将丢失应用程序的状态。 如何保留应用状态?

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

    『Dva』深入解析 Dva 进阶特性:打造健壮的前端应用

    本文将深入探讨 Dva 中的高级特性,包括全局错误处理、中间件配置以及状态初始化等重要概念。 在上一篇文章当中给大家详细的介绍完了 Dva 中的路由之间的跳转,以及如何在 Dva 中使用路由。...如何验证,直接访问浏览器,查看页面上的数据: 可以看到,页面上的数据已经变成了 777,说明我们通过 initialState 成功初始化了 home 模型的状态。..., 访问页面,数据正常显示。...接下来,我将 .catch() 中的错误去掉: 这样就会在 onError 中捕获错误,然后访问页面,点击获取按钮,这会发现页面上弹出了一个提示框,提示框中显示了错误信息,说明我们通过 onError...二、总结 本文深入探讨了 Dva 的几个重要进阶特性: initialState - 用于初始化全局状态 可以在创建 dva 实例时统一配置初始状态 优先级高于 Model 中定义的初始状态 需要注意完整初始化所有用到的状态字段

    18031

    angular面试题及答案_angular面试

    问题就在于请求/响应中消耗了大量时间,或者是重新加载使用了大量时间。而在SPA技术中,即使URL不断变化,我们也只维护一个页面(index.HTML)。 13....当没有配置base标签时,加载应用会失败。 23....Angular的懒加载 默认情况下,在初始化的时候所有路由都会加载,导致加载缓慢,启动速度慢,所以可以使用懒加载 懒加载 : 通俗 的讲就是进入主模块之后,子模块不加载,等真正访问到子模块之后,再去加载...6)如果应用程序较大时,我会考虑延迟加载而不是完全捆绑的应用程序。 27. 使用Angular的好处 可以添加自定义的directive. 优秀的社区支持。 客户端和服务器的通讯非常便利。...32.模板驱动表单和 响应式表单的比较 Template-Driven Forms (模板驱动表单) 的特点 使用方便 适用于简单的场景 通过 [(ngModel)] 实现数据双向绑定

    11.3K120

    2023 React 生态系统,以及我的一些吐槽……

    这在实现当今应用程序中使用的其他行为时变得更加复杂: 跟踪加载状态以显示 UI 加载指示器 避免对相同数据进行重复请求 进行乐观更新以提高 UI 响应速度 随着用户与 UI 进行交互,管理缓存的生命周期...字段,并在组件挂载和卸载时管理缓存数据的生命周期 RTK Query 提供了“缓存条目生命周期”选项,可以通过 WebSocket 消息流式传输缓存更新,以在获取初始数据后使用 我们有从 OpenAPI...Formik 是一个小型库,可以帮助您解决以下三个最令人讨厌的问题: 将值放入和取出表单状态 验证和错误消息 处理表单提交 通过将所有这些放在一个地方,Formik 可以让事情井然有序,使得测试、重构和理解您的表单变得轻而易举...不是因为我认为 React 在实现表单方面采取了错误的方法,而是因为在使用 React 时,表单是最具挑战性的问题。 许多框架都有自己的解决方案来处理表单。AngularJS 在这方面做得非常好。...此外,Formik 依赖于表单元素,并且在控制 Redux 存储时存在一些挑战。

    78430

    React中的Redux

    建议的方式是使用指定的 React Redux 组件 来让所有容器组件都可以访问 store,而不必显示地传递它。只需要在渲染根组件时使用即可。...注意 本函数设计的时候有点偏主观,就是为了避免新手犯一些常见错误。也因些我们故意设定一些规则,但如果你自己手动编写根 redcuer 时并不需要遵守这些规则。...当过早 return 时非常容易犯这个错误,为了避免错误扩散,遇到这种情况时 combineReducers 会抛异常。...我们先来分析一下状态,列表页面的状态。 状态(state) 是一种数据结构,存储在store中的数据 异步加载的页面的状态:“加载中;加载成功,展示列表;加载失败” 这三种状态。...事件 列表展示过程中的数据,也就是:“开始加载;加载成功;加载失败”这三个事件。其实整个过程和之前使用promise来实现的异步操作是一样的。

    4K20

    React与Redux开发实例精解

    (这里的this指的是组件实例) 2.理想状态下,程序的所有数据都应该放在Redux的全局状态中 3.如果一些状态只在一个组件内部临时使用,也可以使用组件的内部状态 十五、React与Redux中的数组处理...、请求成功和请求失败时被发起 十八、Universal渲染 1.预载数据指的是在服务端准备好数据后再渲染页面,这样浏览器接收到的才是携带数据的页面。...2.配置路由匹配信息,可以告诉路由如何根据URL来运行和显示相应的组件 3.Link组件的功能和标签相似,但是它支持一些可用于激活状态的属性 4.要实现服务端路由,只需要在Express中间件加上一个匹配路由的函数...,并在其回调中进行渲染即可 二十一、多页面下的异步操作 1.redux-amrc封装了Redux中的重复性异步操作,只需要将Promise和key值传给redux-amrc,它会完成接下来的所有异步操作...是一个用来加载Bootstrap的Webpack加载器,使用Sass处理CSS样式,对于Bootstrap 3&4都能支持 2.PostCSS是一个使用JS插件转换样式的工具,Autoprefixer是最流行的

    2.1K20

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

    它将引导您完成使用React类组件的数据获取,如何使用Render Prop 组件和高阶组件来复用这些数据,以及它如何处理错误以及 loading 的。...但是,如果你对错误处理、loading、如何触发从表单中获取数据或者如何实现可重用的数据获取的钩子。请继续阅读。 如何自动或者手动的触发 hook?...然而,所有的这些状态,通过他们自己的状态管理,都属于同一个整体,因为他们所关心的数据状态都是请求相关的。正如你所看到的,他们都在 fetch 函数中使用。...在我们的例子中,数据,加载和错误状态的初始状态的参数没有改变,但它们已经聚合到一个由 reducer hook 而不是单个state hook 管理的状态对象。...我之前已经在这里写过关于这个问题的文章,它描述了如何防止在各种场景中为未加载的组件中设置状态。

    28.5K20

    使用 TypeScript 编写 React.js 应用 | 笔记

    SCSS 语法 (.scss) 最常使用。 它是 CSS 的超集,这意味着所有有效的 CSS 也是有效的 SCSS。...,以便我们可以在组件的 state 中保存表单错误。...单击表单上的保存按钮 验证卡片是否显示更新的数据 刷新浏览器 验证项目是否仍处于更新状态 注意: 更新后卡片会被排到最后, 目前没有在代码中排序 错误推断, 发现并不对, db.json 保存更新并不会重新排序...Redux: 使 Redux 与 React 结合 重构页面(容器)组件以使用 React Redux Hooks 重构表单组件以调度操作 (dispatch an action) 重构页面(容器)组件以使用...React Redux Hooks 删除页面(容器)组件的本地状态,并使用 useSelector 替换为 Redux 状态。

    87990

    百度前端高频react面试题(持续更新中)_2023-02-27

    props的不可以变性就保证的相同的输入,页面显示的内容是一样的,并且不会产生副作用 高阶组件存在的问题 静态方法丢失(必须将静态方法做拷贝) refs 属性不能透传(如果你向一个由高阶组件创建的组件的元素添加...受控组件更新state的流程: 可以通过初始state中设置表单的默认值 每当表单的值发生变化时,调用onChange事件处理器 事件处理器通过事件对象e拿到改变后的状态,并更新组件的state 一旦通过...(2)非受控组件 如果一个表单组件没有value props(单选和复选按钮对应的是checked props)时,就可以称为非受控组件。在非受控组件中,可以使用一个ref来从DOM获得表单值。...input} /> ); } } 总结: 页面中所有输入类的...,页面就无法加载出来。

    2.3K30

    美团前端一面必会react面试题4

    props 是不可修改的,所有 React 组件都必须像纯函数一样保护它们的 props 不被更改。state 是在组件中创建的,一般在 constructor中初始化 state。...受控组件更新state的流程:可以通过初始state中设置表单的默认值每当表单的值发生变化时,调用onChange事件处理器事件处理器通过事件对象e拿到改变后的状态,并更新组件的state一旦通过setState...(2)非受控组件 如果一个表单组件没有value props(单选和复选按钮对应的是checked props)时,就可以称为非受控组件。在非受控组件中,可以使用一个ref来从DOM获得表单值。...如何避免重复发起ajax获取数据?数据放在redux里面在使用 React Router时,如何获取当前页面的路由或浏览器中地址栏中的地址?...,页面就无法加载出来。

    3K30

    react面试题笔记整理

    比较有趣的是,React 实际上并不将事件附加到子节点本身。React 使用单个事件侦听器侦听顶层的所有事件。这对性能有好处,也意味着 React 在更新 DOM 时不需要跟踪事件监听器。...在使用 React Router时,如何获取当前页面的路由或浏览器中地址栏中的地址?...所以即便在回调函数里,你拿到的还是初始的 props 和 state。如果想得到“最新”的值,可以使用 ref。...其他方式在列表需要频繁变动时,使用唯一 id 作为 key,而不是数组下标。必要时通过改变 CSS 样式隐藏显示组件,而不是通过条件判断显示隐藏组件。...类组件和函数组件之间的区别是啥?类组件可以使用其他特性,如状态 state 和生命周期钩子。当组件只是接收 props 渲染到页面时,就是无状态组件,就属于函数组件,也被称为哑组件或展示组件。

    2.7K30

    美团前端react面试题汇总

    页面没使用服务渲染,当请求页面时,返回的body里为空,之后执行js将html结构注入到body里,结合css显示出来;SSR的优势:对SEO友好所有的模版、图片等资源都存在服务器端一个html返回所有数据减少...尤其是针对大型单页应用,打包后文件体积比较大,普通客户端渲染加载所有所需文件时间较长,首页就会有一个很长的白屏等待时间。...super() this.state = { allProps: {} } } // 第一遍需初始化所有组件初始状态...当用户提交表单时,前面提到的元素的值将随表单一起被发送。...但在 React 中会有些不同,包含表单元素的组件将会在 state 中追踪输入的值,并且每次调用回调函数时,如 onChange 会更新 state,重新渲染组件。

    5.1K30

    React面试八股文(第一期)

    使用了 Redux,所有的组件都可以从 store 中获取到所需的 state,他们也能从store 获取到 state 的改变。这比组件之间互相传递数据清晰明朗的多。...受控组件更新state的流程:可以通过初始state中设置表单的默认值每当表单的值发生变化时,调用onChange事件处理器事件处理器通过事件对象e拿到改变后的状态,并更新组件的state一旦通过setState...方法更新state,就会触发视图的重新渲染,完成表单组件的更新受控组件缺陷: 表单元素的值都是由React组件进行管理,当有多个输入框,或者多个这种组件时,如果想同时获取到全部的值就必须每个都要编写事件处理函数...(2)非受控组件 如果一个表单组件没有value props(单选和复选按钮对应的是checked props)时,就可以称为非受控组件。在非受控组件中,可以使用一个ref来从DOM获得表单值。...= input} /> ); }}总结: 页面中所有输入类的

    3.1K30

    翻译 | 我在 React-Native app开发中曾经犯过的11个错误

    ToDos和Friends reducers用于储存实体,从名字很容易知道他们是干什么的.当我进入到ToDo Detail页面中-我只需要根据id来搜索所有的ToDos....错误的container结构.没有从一开始就使用smart/dumb组件 当你初始化一个RN项目,在index.ios.js文件中已经有了样式,存储在一个独立的对象中....正如你看到的,所有的样式都放在独立的模块中-好的.没有代码复制(目前为止). 但是我们到底多长时间才在表单中使用一个字段?...一定要把样式分到独立的模块中.这会让你远离行内样式. 8.使用redux来验证表单 这是我的项目中的错误.希望能对你有帮助....但有时,模块会崩溃.或者不像描述的那样工作.这就是你为什么需要读源码.通过读源码,你可以理解错误在哪里.或许模块是很坏的.或是是你使用的方法不对.另外就是-如果你读了其他模块的代码,你会了解到如何构建你自己的模块

    74520

    React进阶(2)-上手实践Redux-如何获取store的数据

    的组合,代码就是文字描述的最佳的体现,解释 你将在本文学习到 编写Redux的的基本流程 如何获取store中公共的数据,并展示到页面上 如何更改store的公共数据,实现组件的数据与store的同步更新...例子对于入门redux是一个非常好的实践,这就好比刚写程序时的Hello-world,虽然麻雀虽小,但是五胀俱全 在React中要使用Redux时,必须先要在命令行终端下进行安装 使用npm或者cnpm...,yarn(使用yarn时,需要先安装它,然后才可以使用)进行安装 yarn add redux // 或者 npm install --save redux 安装完后,可以在根目录下package.json...Redux中的reducer去管理,在当前组件内部通过getState()方法拿到state数据,最终渲染到页面上 梳理一下Redux的使用流程: 1. ...进而store就获取到了reducer函数里面的组件公共存储的数据,当组件外部想要拿store的公共数据时 于是引入store,并通过getState这个函数就可以获取store中的所有数据,最终可将数据渲染到页面上

    2.3K20

    安卓软件开发:基于Jetpack Compose实现Redux架构

    理解概念 Redux 有几个核心概念,需要先了解它们在做什么: 1. Store(仓库) • 整个应用只有一个Store。Store是一个数据仓库,保存着当前应用的所有状态 (State)。...State(状态) • 你应用中所需维护的所有数据都放在这里,比如登录状态、用户信息、界面上的各种选项状态等。...根据状态显示加载中、错误信息、或登录成功@Composablefun LoginScreen( viewModel: LoginViewModel = viewModel() // 通过DI传入)...{ val loginState by viewModel.loginState.collectAsState() // 登录表单本地State(也可以放到Redux管理,但通常只放必要的全局数据到...UI 收到新 State,再次重新组合: • 成功则显示“已登录”以及“退出登录”按钮; • 失败则显示错误信息。

    6810

    Luna:你想要的 React Native 调试工具

    四大版块的功能如下: 1)Log 版块 Log 版块接管了 console.log,将所有 Log 和未捕获的错误收集到 Luna ,然后倒序展示出来。...3-1.png 所以如何保证 Luna 在各个页面都能访问到,并且还能保留不同页面数据、以及在发生错误时不影响到 Luna,同时还要减少页面接入的成本,成为了一个难题。那么 Luna 是怎么做的呢?...首先,Luna 将初始化与页面注册解耦,将 Luna.init 前置到了应用初始化时。这使得数据的收集与页面的注册分离,保证了页面的切换不会导致数据的丢失。...它具有以下特点: 支持多行文本的展开与收缩,收缩时只显示部分内容; 对大数组与对象采取了懒加载方案,展开后只展示小于 100 行的内容,用户每点击一次剩余部分(N),则展示后 N*100 条数据。...这样就减少了用户滑动的频率; 我们还计划对 Luna 进行更严格的日志分页加载,将显示和存储的 Log 列表分开,在滑动进行到底时,获取存储的 Log 列表的「下一页」,彻底保证动态数据产生过程中的列表滑动性能

    2K20

    React进阶(2)-上手实践Redux-如何获取store的数据

    +Flux的组合,代码就是文字描述的最佳的体现,解释 你将在本文学习到 编写Redux的的基本流程 如何获取store中公共的数据,并展示到页面上 如何更改store的公共数据,实现组件的数据与store...Hello-world,虽然麻雀虽小,但是五胀俱全 在React中要使用Redux时,必须先要在命令行终端下进行安装 使用npm或者cnpm,yarn(使用yarn时,需要先安装它,然后才可以使用)进行安装...this.state = { inputValue: 'itclanCoder', // input表单初始值 list: ['itclanCoder', '川川',...进而store就获取到了reducer函数里面的组件公共存储的数据,当组件外部想要拿store的公共数据时 于是引入store,并通过getState这个函数就可以获取store中的所有数据,最终可将数据渲染到页面上...这个的决定,最终该函数返回最新结果会返回给store,完成新旧数据的替换, 而在组件中如何获取store的数据,是通过getState方法进行获取store中的所有状态 那么如何保持页面的组件与store

    1.6K10
    领券