今天学习了react高阶组件,刚接触react学习起来还是比较困难,和大家分享一下今天学习的知识吧,另外缺少的地方欢迎补充哈哈

高阶组件(Higher Order Components,简称:HOC)

是 React 中用于重用组件逻辑的高级技术, 它本身不是react中的组件, 而是一个函数,
 这个函数接受一个react组件作为参数,并返回一个新组件, 实现了对原有组件的增强和优化, 
可以对原有组件中的state, props和逻辑执行增删改操作, 一般用于代码重用和组件增强优化。

高阶组件的使用场景

1, 需要代码重用时, react如果有多个组件都用到了同一段逻辑, 这时,就可以把共同的逻辑部分提取出来,
利用高阶组件的形式将这段逻辑整合到每一个组件中, 从而减少代码的逻辑重复。
2, 需要组件增强优化时, 比如我们在项目中使用的组件有些不是自己写的, 而是从网上C下来的, 
但是第三方写的组件可能比较复杂, 有时不能完全满足需求, 但第三方组件不易修改, 此时也可以用高阶组件,
在不修改原始组件的前提下, 对组件添加满足实际开发需求的功能。
 

高阶组件的实现方式

高阶组件的实现方式有两种:

1, 属性代理: 通过创建新组建来包裹原始组件, 把原始组件作为新组建的子组件渲染  
   功能: 可实现对原始组件的 props数据更新 和 组件模板更新。
  下面是实现属性代理的代码片段:
  (1), 新建高阶组件文件 MyHOC.jsx
  (2), 在文件中创建函数 函数的参数是一个组件OldCom(参数可以自定义), 函数的返回值也是一个组件 NewCom(自定义)
  

function MyHoc(OldCom){
return class NewCom extends React.Component{
render(){
let newProps = { age: 10, sex: '男' }
return (
<OldCom {...newProps} ></OldCom>
)
}
}
} // 导出高阶组件函数
export default MyHOC; // 属性代理: 通过创建新组建来包裹原始组件, 把原始组件作为新组建的子组件渲染
// 功能: 可实现对原始组件的 props数据更新 和 组件模板更新
 
2, 反向继承: 通过创建新组建继承自原始组件, 把原始组件作为父组件 
  功能: 可实现对原始组件的state状态数据更新 和 组件模板更新。
  下面是实现反向继承的代码片段:
  

 1 function MyHOC (OldCom){
2 return class NewCom extends OldCom{
3 componentDidMount() {
4 this.setState({ name: '李四' })
5 }
6 render() {
7 return super.render()
8 }
9 }
10 }
11
12 // 导出高阶组件函数
13 export default MyHOC;
14
15 // 反向继承的state数据, 不能在render中改, 会进入死循环
16 // 一般在生命周期函数或自定义函数中更新state
 

高阶组件的渲染劫持

通过高阶组件可以把原始组件的模板进行修改和替换
渲染劫持指对一个组件渲染内容的装饰或修改, 一般通过高阶组件来实现, 
把一个组件传入高阶组件, 可以对这个组件的模板进行修改后执行渲染, 
也可以阻止组件渲染,并修改组件中的数据和逻辑。
下面是渲染劫持的代码片段
 1 function MyHOC (OldCom){
2 return class NewCom extends OldCom{
3 componentDidMount() {
4 this.setState({ name: '李四' })
5 }
6 render() {
7 // 以下模拟订单页渲染, 从状态管理中取出登录状态, 加以判断
8 let isLogin = true;
9 if(isLogin){
10
11 // 此时,要渲染父组件,就要用父组件对象super渲染
12 return super.render()
13 }else{
14 this.props.history.push("/login")
15 return null
16 }
17 }
18 }
19 }
20 export default MyHOC
 
 

渲染劫持的应用

 一般用于一些需要登录状态的页面, 在路由请求渲染页面(如订单页)之前, 
使用高阶组件判断是否已登录,如果已登录,返回订单页模板, 如果没有登录,返回空,并跳转到登录页
 
 

最后在使用用高阶组件的时候,别忘了导入组件,

路径改成你文件路径导入:

import 自定义名称 from "高阶组件所在路径"
 
 
 
 
 

是发

react高阶组件的一些运用的更多相关文章

  1. 聊聊React高阶组件(Higher-Order Components)

    使用 react已经有不短的时间了,最近看到关于 react高阶组件的一篇文章,看了之后顿时眼前一亮,对于我这种还在新手村晃荡.一切朝着打怪升级看齐的小喽啰来说,像这种难度不是太高同时门槛也不是那么低 ...

  2. 当初要是看了这篇,React高阶组件早会了

    当初要是看了这篇,React高阶组件早会了. 概况: 什么是高阶组件? 高阶部件是一种用于复用组件逻辑的高级技术,它并不是 React API的一部分,而是从React 演化而来的一种模式. 具体地说 ...

  3. react高阶组件的理解

    [高阶组件和函数式编程] function hello() { console.log('hello jason'); } function WrapperHello(fn) { return fun ...

  4. 函数式编程与React高阶组件

    相信不少看过一些框架或者是类库的人都有印象,一个函数叫什么creator或者是什么什么createToFuntion,总是接收一个函数,来返回另一个函数.这是一个高阶函数,它可以接收函数可以当参数,也 ...

  5. React高阶组件学习笔记

    高阶函数的基本概念: 函数可以作为参数被传递,函数可以作为函数值输出. 高阶组件基本概念: 高阶组件就说接受一个组件作为参数,并返回一个新组件的函数. 为什么需要高阶组件 多个组件都需要某个相同的功能 ...

  6. 利用 React 高阶组件实现一个面包屑导航

    什么是 React 高阶组件 React 高阶组件就是以高阶函数的方式包裹需要修饰的 React 组件,并返回处理完成后的 React 组件.React 高阶组件在 React 生态中使用的非常频繁, ...

  7. React——高阶组件

    1.在React中higher-order component (HOC)是一种重用组件逻辑的高级技术.HOC不是React API中的一部分.HOC是一个函数,该函数接收一个组件并且返回一个新组件. ...

  8. react 高阶组件的 理解和应用

    高阶组件是什么东西 简单的理解是:一个包装了另一个基础组件的组件.(相对高阶组件来说,我习惯把被包装的组件称为基础组件) 注意:这里说的是包装,可以理解成包裹和组装: 具体的是高阶组件的两种形式吧: ...

  9. react高阶组件的使用

    为了提高代码的复用在react中我们可以使用高阶组件 1.添加高阶组件 高阶组件主要代码模板HOC.js export default (WrappedComponent) => { retur ...

随机推荐

  1. LoRaWAN和LoRa的区别在那里?

    有很多人都分不清楚LoRaWAN和LoRa到底有什么区别,甚至有人认为它们是一样的,但其实这两个不一样的. LoRa是一个物理层的协议,而LoRaWAN则指的是MAC层的组网协议.虽然现有的LoRaW ...

  2. python使用pip安装第三方模块遇到的问题及解决方法

    python使用pip安装第三方模块遇到的问题及解决方法 关注公众号"轻松学编程"了解更多. 使用国内源: 清华:https://pypi.tuna.tsinghua.edu.cn ...

  3. Java基础—反射与代理(新手向)

    第1章 反射与代理 1.1 反射定义 一般情况下,需要一个功能的前提是遇到了某个问题,这里先列举一些问题,然后再通过反射是如何解决了这些问题,来引出反射的定义. 普通开发人员工作中最常见的问题:需要生 ...

  4. 【QT】子类化QThread实现多线程

    <QThread源码浅析> 子类化QThread来实现多线程, QThread只有run函数是在新线程里的,其他所有函数都在QThread生成的线程里.正确启动线程的方法是调用QThrea ...

  5. angularJS 小记

    刚刚接触angularJS,网上学习了一遍菜鸟教程(http://www.runoob.com/angularjs/angularjs-tutorial.html),做了些基础知识的笔记. Angul ...

  6. python的数据处理一

    def load_data(filename): features = [] labels = [] f = open(filename, encoding='utf-8') medical = js ...

  7. leetcode1Minimum Depth of Binary Tree

    题目描述 求给定二叉树的最小深度.最小深度是指树的根结点到最近叶子结点的最短路径上结点的数量. Given a binary tree, find its minimum depth.The mini ...

  8. 3.java设计模式之工厂模式

    基本需求: 一个披萨店需要订购不同种类的披萨 传统方式: 实现思路 在订购类中根据用户不同的输入直接创建不同的披萨实体类进行返回 UML类图 代码实现 披萨类 // 抽象父类 public abstr ...

  9. Redis 数据结构之字符串的那些骚操作

    Redis 字符串底层用的是 sds 结构,该结构同 c 语言的字符串相比,其优点是可以节省内存分配的次数,还可以... 这样写是不是读起来很无聊?这些都是别人咀嚼过后,经过一轮两轮三轮的再次咀嚼,吐 ...

  10. go-zero之web框架

    go-zero 是一个集成了各种工程实践的 web 和 rpc 框架,其中rest是web框架模块,基于Go语言原生的http包进行构建,是一个轻量的,高性能的,功能完整的,简单易用的web框架 服务 ...