[React] 自定义hooks设计模式

news/2024/7/15 2:05:47 标签: react.js, 设计模式, javascript

文章目录

      • 1.自定义hooks设计
        • 1.1 自定义hooks
        • 1.2 设计一个自定义hooks
        • 1.3 自定义hooks的驱动条件
        • 1.4 自定义hooks的通用模式
        • 1.5 自定义hooks的条件限定

1.自定义hooks设计

react-hooks是react16.8以后,react新增的钩子API,目的是增加代码的可复用性,逻辑性,弥补无状态组件没有生命周期,没有数据管理状态state的缺陷。react-hooks思想和初衷,也是把组件,颗粒化,单元化,形成独立的渲染环境,减少渲染次数,优化性能。

1.1 自定义hooks

自定义hooks是在react-hooks基础上的一个拓展,可以根据业务需要制定满足业务需要的hooks,更注重的是逻辑单元。

通过业务场景不同,我们到底需要react-hooks做什么,怎么样把一段逻辑封装起来,做到复用,这是自定义hooks产生的初衷。

1.2 设计一个自定义hooks

在这里插入图片描述

hooks 专注的就是逻辑复用, 是我们的项目,不仅仅停留在组件复用的层面上。hooks让我们可以将一段通用的逻辑存封起来。将我们需要它的时候,开箱即用即可。

1.3 自定义hooks的驱动条件

hooks本质上是一个函数。函数的执行,决定与无状态组件组件自身的执行上下文。每次函数的执行(本质上就是组件的更新)就会执行自定义hooks的执行,由此可见组件本身执行和hooks的执行如出一辙。

那么prop的修改,useState,useReducer使用是无状态组件更新条件,那么就是驱动hooks执行的条件。 我们用一幅图来表示如上关系。

在这里插入图片描述

1.4 自定义hooks的通用模式

在这里插入图片描述

const [ xxx , ... ] = useXXX(参数A,参数B...)

编写hooks的时候, 需要注意传入和返回的值。

1.5 自定义hooks的条件限定

如果自定义hooks没有设计好,比如返回一个改变state的函数,但是没有加条件限定限定,就有可能造成不必要的上下文的执行,更有甚的是组件的循环渲染执行。

import React, {useEffect, useMemo, useState} from 'react';

// const mock_data = [
//     {
//         name: '1',
//         age: 1
//     },
//     {
//         name: "2",
//         age: 2
//     }
// ]

function useFormatList(list){
    return list.map(item=>{
       console.log(1111)
       return item.toUpperCase()
   })
}

const list = [ 'aaa' , 'bbb' , 'ccc'  ]
function UseHooks(props) {
    const [num, setNum] = useState(0)
    const newList = useFormatList(list)

    return <div>
        <div className="list" >
            { newList.map(item=><div key={item} >{ item }</div>) }
        </div>
        <div className="number" >
            <div>{ num }</div>
            <button onClick={()=> setNum(num + 1) } >add</button>
        </div>
    </div>
}

export default UseHooks;

格式化父组件传递过来的list数组,并将小写变成大写,但是当我们点击add。 理想状态下数组不需要重新format,但是实际跟着执行format。无疑增加了性能开销。

function useFormatList(list) {
    return useMemo(() => list.map(item => {
        console.log(1111)
        return item.toUpperCase()
    }), [])
}

所以一个好用的自定义hooks,一定要配合useMemo ,useCallback 等api一起使用。


http://www.niftyadmin.cn/n/5044301.html

相关文章

vue点击容器外隐藏元素(点击非本身以外的部分隐藏元素)

如图点击蓝色边框以外任意地方隐藏蓝色边框容器&#xff08;不使用输入框的失焦事件&#xff09; 实现思路&#xff1a; 获取到dom节点然后通过其contains方法来判断点击的地方是否为其子元素或其本身 原生js获取dom跟vue的$el都可以实现 也可以通过vue的this.$refs.showBox…

vue之Pinia

定义 Store | Pinia 开发文档 1.什么是Pinaia Pinia 是 Vue 的专属状态管理库&#xff0c;它允许你跨组件或页面共享状态。 2.理解Pinaia核心概念 定义Store 在深入研究核心概念之前&#xff0c;我们得知道 Store 是用 defineStore() 定义的&#xff0c;它的第一个参数要求是一…

算法通关村第15关【黄金】| 海量数据场景下热门问题

1. 对20GB文件进行排序 题目要求: 假设你有一个20GB的文件&#xff0c;每行一个字符串&#xff0c;请说明如何对这个文件进行排序? 分块&#xff1a;先将20GB的文件分块&#xff0c;如果我们只有10GB的内存空间&#xff0c;可以分成20块&#xff0c; 排序&#xff1a;然后单…

电阻的串并联

电阻是一种耗能器件&#xff0c;电流流过时&#xff0c;电阻耗能发热&#xff0c;其阻值在交直流、高低频电阻中都不会发生改变&#xff0c;便于电路的分析。 电路分为两种串联和并联。 1、串联&#xff1a; 电阻串联在电阻中总阻值累加增大&#xff0c;RR1R2R3.........&…

Swagger生成Markdown文档

前提条件 1、 本地安装node.js&#xff0c;或者解压安装包 配置环境变量→ 任意路径输入CMD 配置环境变量→ 解压路径输入CMD2、npm换源&#xff08;不然下载仓库有可能报错&#xff09; npm config get registry 查看源n…

Android 12 Bluetooth源码分析蓝牙配对

本文主要是列出一些蓝牙配对重要的类和方法/函数&#xff0c;遇到相关问题时方便查找添加log排查。 蓝牙扫描列表页面&#xff1a;packages/apps/Settings/src/com/android/settings/bluetooth/DeviceListPreferenceFragment.java点击其中一个设备会调用&#xff1a;onPrefere…

springboot的配置变量

获取配置信息 如果是被spring容器所管理&#xff0c;一般采用Value注解就可以读取到application.yml文件的内容。 但是不被spring容器管理&#xff0c;使用Value是无效的。注入时会是NULL。但就是会有这样的场景&#xff0c;此时可采用在springboot启动类中将环境注入到某一个…

MongoDB 是什么和使用场景概述(技术选型)

一、从NOSQL(Not Only SQL)说起 常见的数据库可以分为下面的两种类型&#xff1a; RDBMS&#xff08;关系型数据库&#xff09;&#xff1a;常见的关系型数据库有 Oracle、DB2、Microsoft SQL Server、Microsoft Access、MySQL&#xff1b;NoSQL&#xff08;非关系型数据库&a…