zoukankan      html  css  js  c++  java
  • react中高阶函数的常见使用方式?

    高阶函数

    使用方式

    • 在导出函数上面使用@HOC,@HOC function() {}
      • @HOC语法通过es7中decorator来实现的,需要配置babel来兼容才可以使用
    • 导出时使用HOC进行包裹,export default HOC(HocComponent)

    高阶函数使应用场景

    • 目的:把常用的逻辑独出来进行多次复用
    • 业务场景:在一个多页H5中,部分页面有查看权限,比如新闻列表,详情,不需要进行任何操作就可以看。但是比如活动抽奖页,如果想参加就需要验证手机号登录,当一些新用户通过分享出去的链接进入活动页时,需要弹出手机号登录验证消息弹窗,同理也有其他的页面需要弹出这个弹窗
    • 常规方式:每个需要弹出弹窗的页面都写一遍逻辑,但是当页面数比较多时,就比较麻烦了,而且代码有很多重复的
    • 采用HOC:编写一个携带弹窗逻辑的高阶函数,在每个需要出现弹窗的页面通过高阶函数包裹一下需要导出的页面组件,即可在页面组件中调用弹窗出现的方法

    原理

    • 属性代理方式原理
      • 向被处理的组件上添加独立出来的属性与方法,并返回一个包含原组件的新组件

    高阶组件使用注意事项

    • 不要在render方法中使用HOC
    • 复制静态方法
    • refs不会被传递

    示例

    • 当前示例中,高阶函数定义了属性与方法,并传入到了新导出的组件中,可以在被高阶函数包装的组件中直接调用高阶函数内部的属性与方法,比如在HocComponent组件中调用高阶函数HOC中的add方法
      import React from 'react'
    
      function HOC(WrapComponent) {
        function ChildComponent(props) {
          const add = (a, b) => {
            return a + b
          }
          const newProps = { type: 'hoc', add }
          return <WrapComponent {...props} {...newProps} />
        }
        return ChildComponent
      }
    
      // @HOC
      function HocComponent(props) {
        console.log(props) // { type: 'hoc', add: f(){} }
        const { add } = props
        console.log(add(1, 2))
        return (
          <div>HocPage</div>
        )
      }
    
      const newHocComponent = HOC(HocComponent)
    
      export default newHocComponent
    
  • 相关阅读:
    NFC学习一个记录
    谈话《百度搜索引擎的网页质量白皮书》
    EBS OAF 发展 URL商标、加密和编码
    绘制一个简单的实现接口盘
    [AngularFire2] Pagination
    [TypeScript] The Basics of Generics in TypeScript
    [TypeScript] Using Assertion to Convert Types in TypeScript
    [TypeScript] Sharing Class Behavior with Inheritance in TypeScript
    [TypeScript] Creating a Class in TypeScript
    [Angular2 Router] Preload lzay loading modules
  • 原文地址:https://www.cnblogs.com/sk-3/p/13808835.html
Copyright © 2011-2022 走看看