首页
学习
活动
专区
工具
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高阶组件

React高阶组件 高阶组件HOC即Higher Order Component是React中用于复用组件逻辑一种高级技巧,HOC自身不是React API一部分,它是一种基于React组合特性而形成设计模式...HOC在React第三方很常见,例如Reduxconnect和RelaycreateFragmentContainer。...= higherOrderComponent(WrappedComponent); 在这里要注意,不要试图以任何方式在HOC修改组件原型,而应该使用组合方式,通过将组件包装在容器组件实现功能。...高阶组件HOC属于函数式编程functional programming思想,对于被包裹组件时不会感知到高阶组件存在,而高阶组件返回组件会在原来组件之上具有功能增强效果,基于此React官方推荐使用高阶组件...修改传入组件HOC是一种糟糕抽象方式,调用者必须知道他们是如何实现,以避免与其他HOC发生冲突。HOC不应该修改传入组件,而应该使用组合方式,通过将组件包装在容器组件实现功能

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

3、React组件this

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

2.9K10

React 受控组件和非受控组件

一些背景 如果初涉 React 应用开发,你可能曾嘀咕过:“受控组件和非受控组件是啥?”。那么建议你额外花点时间先看看官网文档。...在 React 应用之所以需要受控组件和非受控组件,起因于、 和 这类特定 DOM 元素默认在 DOM 层维持状态(用户输入)。...受控组件用来在 React 也保存该状态,比如同步到渲染输入元素组件、树结构某个父组件,或者一个 flux store 。 而这种模式可以被扩展至特定非 DOM 状态相关用例。...比如,在最近一个应用需要创建一个可嵌套 Collapsible 折叠组件,支持两种操作模式:某些情况下需要使其被外界可控(当应用其他区域发生用户交互时扩展开),其他时候它能简单自己管理状态就可以了...React Inputs 对于 React Inputs,是这样工作: 要创建一个非受控 input,要设置一个 defaultValue 属性。

2.7K20

如何实现React组件鉴权功能

权限控制算是软件项目中常用功能了。在前端项目开发过程,权限控制一般分为两个维度:页面级别和页面元素级别。 今天我们来聊一下在React项目中如何实现页面元素级别的鉴权功能。...接下来我们用React高阶组件方式和ReactRender Prop方式分别实现一下React组件鉴权功能。...https://react.docschina.org/docs/render-props.html 用大白话来讲,就是将组件通用逻辑提取到一个公共组件,这个公共组件渲染内容由其参数render...以上便是使用React高阶组件方式和ReactRender Prop方式分别实现一下React组件鉴权功能,如果你有什么建议或者想法欢迎留言。...下篇文章用React自定义hook函数来实现组件鉴权功能

2.9K30

react组件向父组件传递数据_react组件改变父组件状态

大家好,又见面了,是你们朋友全栈君。...本博客代码是 React组件和子组件相互传值 demo;实现封装一个折线图,折线图选择下拉框,获取下拉框点击值并且传给父组件根据下拉框筛选条件更新视图;效果图如下: 父组件代码: 代码解析:...父组件 Parent 引用子组件 Sub ,传递了 list 组件给子组件,并且接收子组件传递给父组件 storeId ; import React, { Component } from 'react...'storeId':1,'name':'li'},{'storeId':2,'name':'jay'}], }; storeId=(value)=> { console.log('子组件传递给父组件值...如发现本站有涉嫌侵权/违法违规内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

3.5K30

聊聊React权限组件设计

1背景 权限管理是后台系统中常见需求之一。之前做过基于 Vue 后台管理系统权限控制[1],基本思路就是在一些路由钩子里做权限比对和拦截处理。...最近维护一个后台系统需要加入权限管理控制,这次技术栈是React刚开始是在网上搜索一些React路由权限控制,但是没找到比较好方案或思路。...这又分为了两部分: 侧边栏菜单 路由权限 在很多人理解,前端权限控制就是左侧菜单可见与否,其实这是不对。...component代表路由对应组件: import React, { createElement } from "react" import Loadable from "react-loadable...直接在组件判断显然不太合适,我们把这部分逻辑抽离出来: /** * 通用权限检查方法 * Common check permissions method * @param { 菜单访问需要权限

2.7K11

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基础(5)-React组件数据-props

[React学习(5)-React组件数据-props.png] 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用...将一个大应用按照功能结构等划分成若干个部分(组件),对每个部分(组件)进行分开管理,与组件相关东西放在一起,达到高内聚目的,而不同组件又各自独立管理达到低耦合效果。...,因为它效能是最高 否则的话,那么就要编写constructor构造器函数,况且Es6编写类方式提供了更多实用功能,特定条件下,该用还是要用 一般而言,在React,构造函数仅用于下面两种情况...通过类型检查捕获一些错误,规避一些程序上bug,React内置了一些类型检查功能,要在组件props上进行类型检查,只需要做一些特定propTypes属性配置即可 定义一个组件,为了该程序严谨性...,应该规范组件数据的如下方面 这个组件支持哪些prop 每个prop应该是什么样格式 在React,借助了第三方库prop-types来解决这一问题,通过PropTypes来支持这一功能 命令行终端下

6.6K00

React组件间通信方式

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

2.4K30

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

React学习(6)-React组件数据-state.png 前言 组件state具体是什么?怎么更改state数据? setState函数分别接收对象以及函数有什么区别?...如何划分组件状态数据,进行自我灵魂拷问,以及props与state灵魂对比 那么本节就是你想要知道 Reactstate 一个组件最终渲染数据结果,除了prop还有state,state代表是当前组件内部状态...要知道 定义: setState方法是ReactReact.Component组件所提供一个内置方法,当你调用这个setState方法时候,React会更新组件状态state,并且重新调用render...,可以通过setState函数修改state 结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React...,觉得至今也在摸索..

6K00

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

如何划分组件状态数据,进行自我灵魂拷问,以及props与state灵魂对比 那么本节就是你想要知道 Reactstate 一个组件最终渲染数据结果,除了prop还有state,state代表是当前组件内部状态...,你可以把组件看成一个'状态机",它是能够随着时间变化数据,更多是应当在实现交互时使用,根据状态state改变呈现不同UI展示 在React,因为不能直接修改外部组件传入prop值 当需要记录组件自身数据变化时...,谁来解愁) (点击小程序,可看视频) ?...结语 本文主要讲述了React组件数据属性-state,它是组件内部状态,是一私有的变量,用于记录组件内部状态,由于props不可修改,通过React内置提供setState方法修改state...,觉得至今也在摸索..

3.6K20

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

撰文 | 川川 前言 开发一个React应用,更多是在编写组件,而React组件最小单位就是React元素,编写组件最大好处,就是实现代码复用 将一个大应用按照功能结构等划分成若干个部分...每个定义React组件应该都是独立存在模块,组件之外一切都是外部世界(组件),外部世界(组件)就是通过prop来和组件进行对话数据传递React,你可以将prop类似于HTML标签元素属性...通过类型检查捕获一些错误,规避一些程序上bug,React内置了一些类型检查功能,要在组件props上进行类型检查,只需要做一些特定propTypes属性配置即可 定义一个组件,为了该程序严谨性...,应该规范组件数据的如下方面 这个组件支持哪些prop 每个prop应该是什么样格式 在React,借助了第三方库prop-types来解决这一问题,通过PropTypes来支持这一功能 命令行终端下...,但在发布产品代码时,用一种自动方式将propTypes去掉,这样在线上坏境代码时最优 借助babel-plugin-transform-react-remove-prop-types这个第三方模块进行配置处理一下

3.4K30

React组件本质

原文始发于我博客 也许你已经使用React很长时间了,你使用优雅jsx语法和React hooks来构建组件,最终构成页面。...然而,为什么我们只需要编写一些声明式组件React就可以管理它自己? 进一步而言,我们每天编写组件到底是什么?...所以一个组件渲染过程其实就是一次函数调用。 这就是为什么在前面的例子我们每一秒都会得到App和Text。 组件状态更新导致了组件重新渲染,触发了函数调用。...将使用以下伪代码来描述ReactDOM和Reconciler关系: ReactDOMRenderer = Reconciler(ReactDOMHostConfig) 代码ReactDOMHostConfig...如果这篇博客有所帮助, 强烈推荐您阅读Dan Abramov很棒博客"将React作为UI运行时"。

1.4K31

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

,做着不同事情 在React编写组件,每个组件在网页中都有被创建,更新,删除这么一过程,就像有机生命体一样 理解生命周期函数对于编写React组件代码是非常重要 如果你不清楚生命周期,以及生命周期应用场景...:可以对照这个完整生命周期图谱 image.png 组件装载(Mount):React组件第一次在DOM树渲染过程 componentWillMount:组件即将被挂载,在Render方法之前调用...应用场景:我们往往在这个生命周期内进行Ajax获取,填充组件内容,因为在componentDidMount被调用时,组件已经挂载到DOM树上了,而往往若需要结合第三方使用,例如:JQ等,也是放到这个生命周期函数中进行处理....gif 大家可以自行将这些生命周期函数放到组件内部当中,进行测试,看每个生命周期执行顺序就一目了然了 说完了组件装载,那么接下来就是组件更新了 组件更新  当props或者state发生改变时候...替代该函数,该函数做了内部优化 // nextProps表示是接下来props值会样,nextState表示state会变成什么样 shouldComponentUpdate(nextProps

2.1K20

React创建组件3种方式

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

2K30
领券