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

React dumb 组件和 smart 组件

原文:https://medium.com/@thejasonfile/dumb-components-and-smart-components-e7b33a698d43 当你开始起步学习 React,...很快就会接触到组件(Component)概念,正是这一概念让 React 脱颖而出。...创建不同组件并将它们嵌套在一起,就能构建出一个应用。听起来再简单不过了,但真实情况还会更复杂些。有两种不同类型组件,称之为 smart 组件和 dumb 组件。...容器组件需要管理自身繁复生命周期,并负责将数据作为 props,向下传递给展示型组件。 smart 组件是基于类,并在 constructor() 函数定义自身 state。...应用组件就是一个很好 smart 组件范例,经常负责管理整个应用若干个 state 片段,并需要将附加功能下发到其子组件,从而实现用户交互时 state 能被更新。

2.5K10

React高阶组件

= higherOrderComponent(WrappedComponent); 在这里要注意,不要试图以任何方式在HOC修改组件原型,而应该使用组合方式,通过将组件包装在容器组件实现功能。...修改传入组件HOC是一种糟糕抽象方式,调用者必须知道他们是如何实现,以避免与其他HOC发生冲突。HOC不应该修改传入组件,而应该使用组合方式,通过将组件包装在容器组件实现功能。...diff算法使用组件标识来确定它是应该更新现有子树还是将其丢弃并挂载新子树,如果从render返回组件与前一个渲染组件相同===,React通过将子树与新子树进行区分来递归更新子树,如果它们不相等...,完全卸载前一个子树。...如果将ref添加到HOC返回组件ref引用指向容器组件,而不是被包装组件,这个问题可以通过React.forwardRef这个API明确地将refs转发到内部组件。。

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

3、React组件this

React组件this是什么 通过编写一个简单组件,并渲染出来,分别打印出自定义函数和renderthis: import React from 'react'; const STR = '被调用...对象; onClick ={this.handler} -> undefined 继续使用事件触发组件装载、更新和卸载过程: /index.js import React from 'react' import...- 面对如此混乱场景,如果我们想在onClick调用自定义组件方法,并在该方法获取组将实例,我们就得进行转换上下文即绑定上下文: 自动绑定和手动绑定 React.createClass有一个内置魔法...,可以自动绑定所用方法,使得其this指向组件实例化对象,但是其他JavaScript类并没有这种特性; 所以React团队决定不再React组件实现自动绑定,把上下文转换自由权交给开发者;...,即onClick={this.handler}打印出来组件实例; 总结: React组件生命周期函数this指向组件实例; 自定义组件方法this会因调用者不同而不同; 为了在组件自定义方法获取组件实例

2.9K10

React 受控组件和非受控组件

一些背景 如果初涉 React 应用开发,你可能曾嘀咕过:“受控组件和非受控组件是啥?”。那么我建议你额外花点时间先看看官网文档。...在 React 应用之所以需要受控组件和非受控组件,起因于、 和 这类特定 DOM 元素默认在 DOM 层维持状态(用户输入)。...受控组件用来在 React 也保存该状态,比如同步到渲染输入元素组件、树结构某个父组件,或者一个 flux store 。 而这种模式可以被扩展至特定非 DOM 状态相关用例。...React Inputs 对于 React Inputs,是这样工作: 要创建一个非受控 input,要设置一个 defaultValue 属性。...因此,如果 onChange() 没被正确处理, input 实际上就成了只读;因为 input 总是靠着 value 属性来渲染其值,用户也就无法改变 input 值了。

2.7K20

为你React工程添加异步组件支持

异步组件 首先,要明白组件概念。React中所有继承React.Component类都是一个React组件React组件可大可小,功能多样。...React组件一般情况下都是静态写死,也就是在代码写死,最终编译成一个index.bundle.js,一次性加载完毕。...但是某些时候,我们需要更加灵活组件引入,只有真正用到这个组件时候才去请求a.component.js,然后再渲染这个组件。一些等到用时再去下载组件就叫做异步组件。...做法 首先,本文编译环境固定为:webpack+React+Typescript。如果不使用webpack同学,本文并不适用。..."module": "esnext", 使用react-loadable封装异步组件 import Loadable from 'react-loadable' import Loading from

1.1K50

React进阶」我在函数组件可以随便写 —— 最通俗异步组件原理

不可能事 我函数组件里可以随便写,很多同学看到这句话时候,脑海里应该浮现四个字是:怎么可能?因为我们印象函数组件,是不能直接使用异步,而且必须返回一段 Jsx 代码。...鬼畜版——我组件可以写异步 即然直接 throw Promise 会在 React 底层被拦截,那么如何在组件内部实现正常编写异步操作功能呢?...既然 React 会拦截组件抛出 Promise 对象,那么如果把 Promise 对象包装一层呢? 于是我们把 Index 内容做修改。...在 React Susponse 是什么呢?那么正常情况下组件染是一气呵成,在 Susponse 模式下组件渲染就变成了可以先悬停下来。 首先解释为什么悬停?...那么对于如上情况,如果每一个页面组件,都加上 componentDidCatch 这样捕获错误,降级 UI 方式,那么代码过于冗余,难以复用,无法把降级 UI 从业务组件解耦出来。

3.5K30

vue3异步组件

什么是异步组件 在Vue,当我们注册全局或局部组件时,它们都是同步地被“立即解析并加载”。这意味着在我们程序初始化时,所有组件都会通过网络被下载到内存,并且在内存占用一定资源。...定义异步组件 Vue3使用defineAsyncComponent() 来定义异步组件,该API入参是一个返回组件选项函数,需要使用 () => import() 函数来导入组件。...在初始渲染时,Suspense 将在内存渲染其默认#default插槽内容。如果在这个过程遇到任何异步依赖,则会进入挂起状态。在挂起状态期间,展示是#fallback后备内容。...这意味着如果组件关系链上有一个 Suspense,那么这个异步组件就会被当作这个 Suspense一个异步依赖。... 关于Vue3异步组件就聊到这里,喜欢小伙伴点赞关注收藏哦

29720

如何实现React组件鉴权功能

权限控制算是软件项目中常用功能了。在前端项目开发过程,权限控制一般分为两个维度:页面级别和页面元素级别。 今天我们来聊一下在React项目中如何实现页面元素级别的鉴权功能。...接下来我们用React高阶组件方式和ReactRender Prop方式分别实现一下React组件鉴权功能。...Header组件中都进行了获取用户权限操作,如果项目中需要鉴权组件比较多,那么所有需要鉴权组件都需要去添加这部分代码,实在是冗余,其实这部分代码是可以被提取出来。...以上便是使用React高阶组件方式和ReactRender Prop方式分别实现一下React组件鉴权功能如果你有什么建议或者想法欢迎留言。...下篇文章用React自定义hook函数来实现组件鉴权功能

2.9K30

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

(this坏境设置),只是单纯用于接收外部组件传来props数据用作展示,并没有UI交互渲染动作 那么就不需要为该React组件实现构造函数 如果是这样,更应该把它转换为函数式(无状态UI)组件...,因为它效能是最高 否则的话,那么就要编写constructor构造器函数,况且Es6编写类方式提供了更多实用功能,特定条件下,该用还是要用 一般而言,在React,构造函数仅用于下面两种情况....png] 因为在React,数据流是单向,不能改变一个组件被渲染时传进来props 之所以这么规定,因为组件复用性,一个组件可能在各个页面上进行复用,如果允许被修改的话,这个组件显示形态会变得不可预测...,应该规范组件数据的如下方面 这个组件支持哪些prop 每个prop应该是什么样格式 在React,借助了第三方库prop-types来解决这一问题,通过PropTypes来支持这一功能 命令行终端下...(props),如果不进行该设置,该组件下定义成员私有方法(函数)将无法通过this.props访问到父组件传递过来prop值 当然,在React,规定了不能直接更改外部世界传过来prop值,这个

6.6K00

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

React学习(6)-React组件数据-state.png 前言 组件state具体是什么?怎么更改state数据? setState函数分别接收对象以及函数有什么区别?...,setTimeout/setInterval等,当然在React绝大多数都是异步处理 对于实现同步,我们可以看一下下面这个代码,先看下效果:点击减号(-)按钮,页面上count变化与控制台上对应关系...,对于在ReactJSX绑定事件处理函数调用setState方法是异步就可以了 如果你需要基于当前state来计算出新值,那么setState函数就应该传递一个函数,而不是一个对象,它可以确保每次调用都是使用最新...,哪个组件应该拥有某个state状态,进行设置,有时候,它们是非常模糊概念 但是在React应该遵循一些原则: 让组件尽可能少状态 如果组件只是用于UI渲染,数组展示,并无复杂页面逻辑交互,那么应该让组件数据定义成....用于记录组件内部状态,如果组件一些数据在某些时刻发生变化,或者做一些页面逻辑交互时,需要更新UI,这个时候就需要使用state来跟踪状态(例如控制一元素显示隐藏来回切换等状态),它由组件本身管理

6K00

React组件通信几种方式

组件向父组件通信 利用回调函数 利用自定义事件机制 回调函数 实现在子组件中点击隐藏组件按钮可以将自身隐藏功能 List3.jsx import React, { Component } from...使用context 下面例子组件关系: ListItem是List组件,List是app组件 ListItem.jsx import React, { Component } from 'react...没有嵌套关系组件通信 使用自定义事件机制 在componentDidMount事件,如果组件挂载完成,再订阅事件;在组件卸载时候,在componentWillUnmount事件取消事件订阅;...以常用发布/订阅模式举例,借用Node.js Events模块浏览器版实现 使用自定义事件方式 下面例子组件关系: List1和List2没有任何嵌套关系,App是他们组件; 实现这样一个功能...React组件间通信几种方式

2.2K30

聊聊React权限组件设计

这又分为了两部分: 侧边栏菜单 路由权限 在很多人理解,前端权限控制就是左侧菜单可见与否,其实这是不对。...整体实现思路也比较简单:现有权限(currentAuthority)和准入权限(authority)做比较,如果匹配渲染和准入权限匹配组件,否则渲染无权限组件(403 页面) 4路由权限 既然是路由相关权限控制...component代表路由对应组件: import React, { createElement } from "react" import Loadable from "react-loadable...直接在组件判断显然不太合适,我们把这部分逻辑抽离出来: /** * 通用权限检查方法 * Common check permissions method * @param { 菜单访问需要权限...他同样用到了上文中check方法来对当前菜单进行权限比对,如果没有权限就直接不展示当前菜单。

2.7K11

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

,setTimeout/setInterval等,当然在React绝大多数都是异步处理 对于实现同步,我们可以看一下下面这个代码,先看下效果:点击减号(-)按钮,页面上count变化与控制台上对应关系...,对于在ReactJSX绑定事件处理函数调用setState方法是异步就可以了 如果你需要基于当前state来计算出新值,那么setState函数就应该传递一个函数,而不是一个对象,它可以确保每次调用都是使用最新...DOM节点更新,如果前后JSX元素不相等,那么React才会更新DOM 如果props或者state能被直接被修改,将会破坏组件复用原则,会出现一些莫名其妙bug 如何划分组件状态数据 无论是props....用于记录组件内部状态,如果组件一些数据在某些时刻发生变化,或者做一些页面逻辑交互时,需要更新UI,这个时候就需要使用state来跟踪状态(例如控制一元素显示隐藏来回切换等状态),它由组件本身管理...结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React内置提供setState方法修改state

3.6K20

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

撰文 | 川川 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用 将一个大应用按照功能结构等划分成若干个部分...(this坏境设置),只是单纯接收外部组件传来props数据用作展示,并没有UI交互渲染动作 那么就不需要为该React组件实现构造函数 如果是这样,更应该把它转换为函数式(无状态UI)组件,因为它效能是最高...(直接更改props值会报错如上图所示) 因为在React,数据流是单向,不能改变一个组件被渲染时传进来props 之所以这么规定,因为组件复用性,一个组件可能在各个页面上进行复用,如果允许被修改的话...,你需要手动绑定this,如果你不进行手动bind绑定,this会是undefined,在Es6用class类创建React组件并不会自动组件绑定this到当前实例对象上 将该组件实例方法进行...,应该规范组件数据的如下方面 这个组件支持哪些prop 每个prop应该是什么样格式 在React,借助了第三方库prop-types来解决这一问题,通过PropTypes来支持这一功能 命令行终端下

3.4K30

React组件间通信方式

React组件间通信方式 React组件间通信包括父子组件、兄弟组件、隔代组件、非嵌套组件之间通信。...实际上如果传入一个基本数据类型给子组件,在子组件修改这个值的话React中会抛出异常,如果对于子组件传入一个引用类型对象的话,在子组件修改是不会出现任何提示,但这两种情况都属于改变了父子组件单向数据流...我们通常会有需要更改父组件需求,对此我们可以在父组件自定义一个处理接受变化状态逻辑,然后在子组件如若相关状态改变时,就触发父组件逻辑处理事件,在Reactprops是能够接受任意入参,此时我们通过...当然如果只是想避免层层传递props且传递层数不多情况下,可以考虑将props进行一个浅拷贝之后将之后组件不再使用props删除后利用Spread操作符即{...handledProps}将其展开进行传递...,Refs提供了一种方式,允许我们访问DOM节点或在render方法创建React元素,在典型React数据流,props是父组件与子组件交互唯一方式,要修改一个子组件,你需要使用新props

2.4K30

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

,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要 如果你不清楚生命周期,以及生命周期应用场景...函数 你可以理解为,第一次渲染时,父组件componentWillReceiveProps函数不会被执行,如果是第二次渲染时,已经存在于父组件,该componentWillReceiveProps...值,告诉React库这个组件在这次更新过程是否要继续,如果该函数返回true,那么继续更新,调用render函数,反之,若函数返回false,那么立刻停止更新过程,便不会执行render函数了 这个函数是提高...,进行业务处理,发送网络请求 注意:在处理业务或发送网络请求时,一定要做好条件比较,否则容易造成死循环 组件卸载 React组件从页面移除时,在卸载过程,只涉及一个生命周期函数componentWillUnmount...要是返回false时,render函数不会渲染 当组件从页面移除时,在卸载之前会触发componentWillUnmount函数,该函数常常用于组件销毁时调用,清理无效定时器timer,取消未完成网络

2.1K20

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

,所以this环境绑定放在这里面也是可以,但是最好是放在constructor构造器函数里面,如果是处理带有后续异步操作或者有副作用订阅事件处理,例如:Ajax数据获取,放到componentDidMount...值,告诉React库这个组件在这次更新过程是否要继续,如果该函数返回true,那么继续更新,调用render函数,反之,若函数返回false,那么立刻停止更新过程,便不会执行render函数了 这个函数是提高...,进行业务处理,发送网络请求 注意:在处理业务或发送网络请求时,一定要做好条件比较,否则容易造成死循环 组件卸载 React组件从页面移除时,在卸载过程,只涉及一个生命周期函数componentWillUnmount...如果是最新,在React17.0版本,生命周期函数如下所示 ?...函数会渲染,要是返回false时,render函数不会渲染 当组件从页面移除时,在卸载之前会触发componentWillUnmount函数,该函数常常用于组件销毁时调用,清理无效定时器timer

1.6K20

React创建组件3种方式

return mycomponent } }) es6class类方式(有状态组件) 注意:无论使用哪种方式创建组件组件名称首字母都必须大小,因为我们写是...问题就在这里,如果传递是一个字符串,那么在创建虚拟DOM对象时,React会认为这是一个原生HTML标签,但是这显然不是一个原生HTML标签,因此去创建一个不存在标签肯定是会报错。...如果首字母大写,那么就会当成一个变量传递进去,这个时候React会知道这是一个自定义组件,因此他就不会报错了。...1.函数式定义和类定义对比        函数式定义组件没有state和生命周期函数且不能访问this,而类定义这些都可以有。...但是在找到Mixins替代方案之前是不会废弃掉React.createClass形式。所以: 能用React.Component创建组件就尽量不用React.createClass形式创建组件

2K30
领券