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

100行JavaScript代码React优雅实现简单组件keep-Alive

,因为某些原因需要临时离开交互场景,则需要对状态进行保存 在 React ,我们通常会使用路由去管理不同页面,而在切换页面时,路由将会卸载掉未匹配页面组件,所以上述列表页例子,当用户从详情页退回列表页时...,会回到列表页顶部,因为列表页组件被路由卸载后重建了,状态被丢失 如何实现 React 状态保存 在 Vue ,我们可以非常便捷地通过 标签实现状态保存,该标签会缓存不活动组件实例...,我们需要研究如何自动保存状态 最初版本react-keep-alive image.png 1500行TypeScript代码React实现组件keep-alive 我这篇文章对源码进行了解析...元素会储存在AliveScope 组件,所以它不能被卸载 使用AliveScope 配合KeepAlive即可达到缓存效果,类似react-keep-alive 首先我们看看AliveScope 组件做了什么事情...image.png 这里按照代码运行逻辑,完整解析了它简单缓存机制实现,思路整体比较清晰,加上代码自己断点调试难度应该比较低,个人觉得这个库设计和思想,都是不错,值得推广,作者也是比较乐意解答问题

5K10

React高阶组件

React高阶组件 高阶组件HOC即Higher Order Component是React中用于复用组件逻辑一种高级技巧,HOC自身不是React API一部分,它是一种基于React组合特性而形成设计模式...描述 高阶组件从名字上就透漏出高级气息,实际上这个概念应该是源自于JavaScript高阶函数,高阶函数就是接受函数作为输入或者输出函数,可以想到柯里化就是一种高阶函数,同样在React文档上也给出了高阶组件定义...,相互耦合,不利于代码维护,此外不同Mixin方法可能会相互冲突。...diff算法使用组件标识来确定它是应该更新现有子树还是将其丢弃并挂载新子树,如果从render返回组件与前一个渲染组件相同===,则React通过将子树与新子树进行区分来递归更新子树,如果它们不相等...如果将ref添加到HOC返回组件,则ref引用指向容器组件,而不是被包装组件,这个问题可以通过React.forwardRef这个API明确地将refs转发到内部组件。。

3.8K10
您找到你想要的搜索结果了吗?
是的
没有找到

3、React组件this

React组件this是什么 通过编写一个简单组件,并渲染出来,分别打印出自定义函数和renderthis: import React from 'react'; const STR = '被调用...JavaScript函数this 我们都知道JavaScript函数this不是在函数声明时候定义,而是在函数调用(即运行)时候定义 var student = { func:...这段代码形象验证了,JavaScript函数this不是在函数声明时候,而是在函数运行时候定义; 同样,React组件也遵循JavaScript这种特性,所以组件方法‘调用者’不同会导致...,可以自动绑定所用方法,使得其this指向组件实例化对象,但是其他JavaScript类并没有这种特性; 所以React团队决定不再React组件实现自动绑定,把上下文转换自由权交给开发者;...,即onClick={this.handler}打印出来组件实例; 总结: React组件生命周期函数this指向组件实例; 自定义组件方法this会因调用者不同而不同; 为了在组件自定义方法获取组件实例

2.9K10

React dumb 组件和 smart 组件

原文:https://medium.com/@thejasonfile/dumb-components-and-smart-components-e7b33a698d43 当你开始起步学习 React,...很快就会接触到组件(Component)概念,正是这一概念让 React 脱颖而出。...这种组件本身只有一个 render() 方法(他们也用不到其他),并且总是表现为 Javascript 函数。不用维护内部 state,不用知道当收到请求时如何改变其展现数据 - 无知便是福。...容器组件需要管理自身繁复生命周期,并负责将数据作为 props,向下传递给展示型组件。 smart 组件是基于类,并在 constructor() 函数定义自身 state。...应用组件就是一个很好 smart 组件范例,经常负责管理整个应用若干个 state 片段,并需要将附加功能下发到其子组件,从而实现用户交互时 state 能被更新。

2.5K10

React基础(5)-React组件数据-props

[React学习(5)-React组件数据-props.png] 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用...构建组件,本质上就是在编写javascript函数,而组件中最重要是数据,在React数据分两种:props和state,当定义一个组件时,它接收任意形参(即props),并用于返回描述页面展示内容...绑定,this会是undefined,在Es6,用class类创建React组件并不会自动组件绑定this到当前实例对象上 将该组件实例方法进行this坏境绑定是React常用手段 代码如下所示..." />, container); 从上面的代码,可以看得出,父组件JSXprop值可以是一个方法,在子组件想要把数据传递给父组件时,需要在子组件调用父组件方法,从而达到了子组件向父组件传递数据形式...|”或字符进行处理也是可以React,可以配置defaultProps进行默认prop值设置,代码如下所示 具体写法: 组件.defaultProps = { prop属性名称: 默认值 }

6.7K00

React基础(6)-React组件数据-state

React学习(6)-React组件数据-state.png 前言 组件state具体是什么?怎么更改state数据? setState函数分别接收对象以及函数有什么区别?...在以上代码,通过给button按钮监听绑定onClick属性挂载点击事件处理函数(上面是handleBtnClick),来达到控制组件stateisShow这个状态,从而让文本显示还是隐藏 显示和隐藏是通过添加...class层叠样式进行设置,但是控制这个行为切换动作,却是js 这里用是箭头函数,如果不用此方法,一定要记得用bind进行this坏境绑定 在代码,通过this.state可以读取当前组件状态...,setTimeout/setInterval等,当然在React绝大多数都是异步处理 对于实现同步,我们可以看一下下面这个代码,先看下效果:点击减号(-)按钮,页面上count变化与控制台上对应关系...共同点: 都是组件数据,是一普通javascript对象,都是用来保存信息,这些信息可以控制组件形态 不同点: props是由父组件传入(类似形参),用于定义外部组件接口,是React组件输入

6K00

React学习(五)-React组件数据-props

撰文 | 川川 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用 将一个大应用按照功能结构等划分成若干个部分...构建组件,本质上就是在编写javascript函数,而组件中最重要是数据,在React数据分两种:props和state,当定义一个组件时,它接收任意形参(即props),并用于返回描述页面展示内容..." />, container); 从上面的代码,可以看得出,父组件JSXprop值可以是一个方法,在子组件想要把数据传递给父组件时,需要在子组件调用父组件方法,从而达到了子组件向父组件传递数据形式...|”或字符进行处理也是可以React,可以配置defaultProps进行默认prop值设置,代码如下所示 具体写法: 组件.defaultProps = { prop属性名称: 默认值 }...这个实例属性来对prop进行规格设置,这样可以在运行代码时,可以根据propTypes判断外部组件是否整整使用组件属性,输入输出类型是否一一对应,保持一致 限于篇幅所示:React数据另一个

3.4K30

React学习(六)-React组件数据-state

在以上代码,通过给button按钮监听绑定onClick属性挂载点击事件处理函数(上面是handleBtnClick),来达到控制组件stateisShow这个状态,从而让文本显示还是隐藏 显示和隐藏是通过添加...,setTimeout/setInterval等,当然在React绝大多数都是异步处理 对于实现同步,我们可以看一下下面这个代码,先看下效果:点击减号(-)按钮,页面上count变化与控制台上对应关系...从上面的代码,在事件处理函数调用setState方法时,当setState函数传递是一个函数时,这个函数接收两个形参数,第一个参数prevState(参数名任意),是先前组件状态时state,而后一个参数...共同点: 都是组件数据,是一普通javascript对象,都是用来保存信息,这些信息可以控制组件形态 不同点: props是由父组件传入(类似形参),用于定义外部组件接口,是React组件输入...结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React内置提供setState方法修改state

3.6K20

React 受控组件和非受控组件

React 应用之所以需要受控组件和非受控组件,起因于、 和 这类特定 DOM 元素默认在 DOM 层维持状态(用户输入)。...受控组件用来在 React 也保存该状态,比如同步到渲染输入元素组件、树结构某个父组件,或者一个 flux store 。 而这种模式可以被扩展至特定非 DOM 状态相关用例。...React Inputs 对于 React Inputs,是这样工作: 要创建一个非受控 input,要设置一个 defaultValue 属性。...这种情况下 React 组件会使用底层 DOM 节点并借助节点组件本身 state 管理该 value。...实现 有一种非常简单模式适用于本项工作,其主要思路如下: 当组件被初始化时,将 xxx 传入值或 xxx 默认值放入 state

2.7K20

React组件通信几种方式

组件向子组件通信 React数据流动是单向,父组件向子组件通信也是最常见;父组件通过props向子组件传递需要信息 Child.jsx import React from 'react'; import...context是一个全局变量,像是一个大容器,在任何地方都可以访问到,我们可以把要通信信息放在context上,然后在其他组件可以随意取到; 但是React官方不建议使用大量context,尽管他可以减少逐层传递...使用context 下面例子组件关系: ListItem是List组件,List是app组件 ListItem.jsx import React, { Component } from 'react...没有嵌套关系组件通信 使用自定义事件机制 在componentDidMount事件,如果组件挂载完成,再订阅事件;在组件卸载时候,在componentWillUnmount事件取消事件订阅;...React组件间通信几种方式

2.3K30

聊聊React权限组件设计

1背景 权限管理是后台系统中常见需求之一。之前做过基于 Vue 后台管理系统权限控制[1],基本思路就是在一些路由钩子里做权限比对和拦截处理。...原代码基于 react 16.x、dva 2.4.1 实现,所以本文是参考了ant-design-pro v1[2]内部对权限管理实现 2所谓权限控制是什么?...这又分为了两部分: 侧边栏菜单 路由权限 在很多人理解,前端权限控制就是左侧菜单可见与否,其实这是不对。...component代表路由对应组件: import React, { createElement } from "react" import Loadable from "react-loadable...直接在组件判断显然不太合适,我们把这部分逻辑抽离出来: /** * 通用权限检查方法 * Common check permissions method * @param { 菜单访问需要权限

2.7K11

React基础(8)-React组件生命周期

,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要 如果你不清楚生命周期,以及生命周期应用场景...一个方法实现,它是一个javascript对象,将虚拟DOM转化为真实DOM,最后通过ReactDOM.render()方法将真实DOM渲染挂载到对应页面位置上 一个组件渲染,经历了以下几个过程...:可以对照这个完整生命周期图谱 image.png 组件装载(Mount):React组件第一次在DOM树渲染过程 componentWillMount:组件即将被挂载,在Render方法之前调用...,在该生命周期函数内,不应该调用setState函数,因为该组件销毁后,将不会被重新渲染 具体实例代码如下所示: import React, { Fragment, Component } from ...(Ajax)请求,清理已注册订阅 把上面的生命周期图谱在代码多写几遍,结合着每个生命周期含义,就不难理解上面那个生命周期图谱了 更多内容,您可关注微信itclanCoder公众号,一个用心分享传递知识有用

2.1K20

React组件间通信方式

React组件间通信方式 React组件间通信包括父子组件、兄弟组件、隔代组件、非嵌套组件之间通信。...实际上如果传入一个基本数据类型给子组件,在子组件修改这个值的话React中会抛出异常,如果对于子组件传入一个引用类型对象的话,在子组件修改是不会出现任何提示,但这两种情况都属于改变了父子组件单向数据流...我们通常会有需要更改父组件需求,对此我们可以在父组件自定义一个处理接受变化状态逻辑,然后在子组件如若相关状态改变时,就触发父组件逻辑处理事件,在Reactprops是能够接受任意入参,此时我们通过...在React应用数据是通过props属性自上而下即由父及子进行传递,但这种做法对于某些类型属性而言是极其繁琐,这些属性是应用程序许多组件都需要,Context提供了一种在组件之间共享此类值方式...,Refs提供了一种方式,允许我们访问DOM节点或在render方法创建React元素,在典型React数据流,props是父组件与子组件交互唯一方式,要修改一个子组件,你需要使用新props

2.4K30

React学习(八)-React组件生命周期

,一个人生,老,病,死.在每个特殊年龄阶段,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要...本质上是通过底层React.CreateElement一个方法实现,它是一个javascript对象,将虚拟DOM转化为真实DOM,最后通过ReactDOM.render()方法将真实DOM渲染挂载到对应页面位置上...组件装载(Mount):React组件第一次在DOM树渲染过程 componentWillMount:组件即将被挂载,在Render方法之前调用: 应用场景: 常用于组件启动工作,例如:Ajax...,在该生命周期函数内,不应该调用setState函数,因为该组件销毁后,将不会被重新渲染 具体实例代码如下所示: import React, { Fragment, Component } from...,取消未完成网络(Ajax)请求,清理已注册订阅 把上面的生命周期图谱在代码多写几遍,结合着每个生命周期含义,就不难理解上面那个生命周期图谱了

1.6K20

如何将多个参数传递给 React onChange?

React ,一些 HTML 元素,比如 input 和 textarea,具有 onChange 事件。onChange 事件是一个非常有用、非常常见事件,用于捕获输入框文本变化。...下面是一个简单示例,其中演示了一个简单输入框,并将其值存储在组件状态。...当用户输入文本时,e.target.value 取得文本域值,该值被保存在 inputValue 状态。最后,inputValue 将被渲染到组件。...结论在本文中,我们介绍了如何使用 React onChange 事件处理函数,并将多个参数传递给它。我们介绍了两种不同方法:使用箭头函数和 bind 方法。...这些技术可以让你在 React 应用程序更好地处理复杂表单逻辑,从而提高用户体验。

2.2K20

React创建组件3种方式

return mycomponent } }) es6class类方式(有状态组件) 注意:无论使用哪种方式创建组件组件名称首字母都必须大小,因为我们写是...这里说明一个问题,很多时候同一种效果往往有很多种实现方式,所以我们在学习过程要避免章节化思维,要对技术进行横向比较,这样能帮你更 加深入理解各种方式优缺点。...1.函数式定义和类定义对比        函数式定义组件没有state和生命周期函数且不能访问this,而类定义这些都可以有。...mixins前世今生 3.如何选择哪种方式创建组件       由于React团队已经声明React.createClass最终会被React.Component类形式所取代。...但是在找到Mixins替代方案之前是不会废弃掉React.createClass形式。所以: 能用React.Component创建组件就尽量不用React.createClass形式创建组件

2K30

javascript如何将字符串转成变量或可执行代码

有这样一个需求:当前作用域内有未知一些变量,其中一个函数可以拿到某个变量名字符串,怎么能在函数内通过传进来字符串取到作用域链变量值,示例小 demo 如下: const name = '周小黑...return value } const str = fn('name') 要解决上面的问题,主要就是怎么将字符串转变成可执行代码?...主要有三种方式: eval() 函数 eval() 函数会将传入字符串当做 JavaScript 代码进行执行,所以下面的字符串可以正确取到变量对应值,eval 对比 new Function 和...setTimeout 定时器 setTimeout 第一个参数我们平时都是传一个函数,它其实也是可以传字符串进去,在浏览器是可以正常执行,在node环境中会报错。...实际上浏览器也是不推荐这么用,另外需要注意是字符串变量只能访问全局作用域,不能访问局部作用域,如果全局作用域中没有,就是 undefined。

34230
领券