关于Free自由协议增发逻辑技术开发详细丨Free模式系统开发项目方案讲解

简介: 本文探讨ahooks 对 DOM 类 Hooks 使用规范,以及在《free dom自由协议质押系统》开发过程中源码是如何去做处理的,有需求和问题的朋友可以来探讨。

本文探讨ahooks 对 DOM 类 Hooks 使用规范,以及在《free dom自由协议质押系统》开发过程中

源码是如何去做处理的,有需求和问题的朋友可以来探讨。

DOM 类 Hooks 使用规范

在这里插入图片描述

这一章节,大部分参考官方文档的 DOM 类 Hooks 使用规范[1]。

一点,ahooks 大部分 DOM 类 Hooks 都会接收 target 参数,本文由V_StPv888整理发布表示要处理的元素。

target 支持三种类型 React.MutableRefObject(通过 useRef 保存的 DOM)、HTMLElement、() => HTMLElement(一般运用于 SSR 场景)。

第二点,DOM 类 Hooks 的 target 是支持动态变化的。如下所示:

export default () => {

const [boolean, { toggle }] = useBoolean();

const ref = useRef(null);

const ref2 = useRef(null);

const isHovering = useHover(boolean ? ref : ref2);

return (

<>

  <div ref={ref}>{isHovering ? 'hover' : 'leaveHover'}</div>

  <div ref={ref2}>{isHovering ? 'hover' : 'leaveHover'}</div>

</>

);

};

那 ahooks 是怎么处理这两点的呢?

getTargetElement

获取到对应的 DOM 元素,这一点主要兼容一点的入参规范。

假如是函数,则取执行完后的结果。

假如拥有 current 属性,则取 current 属性的值,兼容React.MutableRefObject 类型。

后就是普通的 DOM 元素。

export function getTargetElement(target: BasicTarget, defaultElement?: T) {

// 省略部分代码...

let targetElement: TargetValue;

if (isFunction(target)) {

// 支持函数获取

targetElement = target();

// 假如 ref,则返回 current

} else if ('current' in target) {

targetElement = target.current;

// 支持 DOM

} else {

targetElement = target;

}

return targetElement;

}

useEffectWithTarget

这个方法,主要是为了支持第二点,支持 target 动态变化。

其中 packages/hooks/src/utils/useEffectWithTarget.ts 是使用 useEffect。

import { useEffect } from 'react';

import createEffectWithTarget from './createEffectWithTarget';

const useEffectWithTarget = createEffectWithTarget(useEffect);

export default useEffectWithTarget;

另外 其中 packages/hooks/src/utils/useLayoutEffectWithTarget.ts 是使用 useLayoutEffect。

import { useLayoutEffect } from 'react';

import createEffectWithTarget from './createEffectWithTarget';

const useEffectWithTarget = createEffectWithTarget(useLayoutEffect);

export default useEffectWithTarget;

两者都是调用的 createEffectWithTarget,只是入参不同。

直接重点看这个 createEffectWithTarget 函数:

createEffectWithTarget 返回的函数useEffectWithTarget接受三个参数,前两个跟 useEffect 一样,第三个就是 target。

useEffectType 就是 useEffect 或者 useLayoutEffect。注意这里调用的时候,没传第二个参数,也就是每次都会执行。

hasInitRef 判断是否已经初始化。lastElementRef 记录的是后一次 target 元素的列表。lastDepsRef 记录的是后一次的依赖。unLoadRef 是执行完 effect 函数(对应的就是 useEffect 中的 effect 函数)的返回值,在组件卸载的时候执行。

一次执行的时候,执行相应的逻辑,并记录下后一次执行的相应的 target 元素以及依赖。

后面每次执行的时候,都判断目标元素或者依赖是

原创声明,本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

相关文章
|
安全 前端开发 JavaScript
swap薄饼交易所系统开发技术详细/方案项目/逻辑需求/步骤指南/功能流程/源码版
Blockchain platform selection: Choose a suitable blockchain platform as the underlying infrastructure, such as Ethereum, Coin Security smart chain, etc. These platforms provide smart contract functions and transaction confirmation mechanisms, making them suitable for building decentralized exchanges
|
8月前
|
安全 AndFix
swap/dapp/lp只涨不跌项目系统开发详细程序/案例开发/功能逻辑/需求设计/源码技术
Developing an LP (Liquidity Pool) system that only rises without falling requires the following steps
|
8月前
|
前端开发 区块链
swap丨dapp智能合约只涨不跌项目系统开发成熟技术/案例设计/逻辑方案/源码指南
合约:import "@openzeppelin/contracts/utils/cryptography/MerkleProof.sol";
|
8月前
|
安全 区块链 AndFix
dapp丨swap丨lp智能合约只涨不跌模式系统开发详细案例/指南教程/步骤项目/源码设计
Requirement analysis: Clarify the functional requirements and business logic of the system. Determine the asset types, transaction rules,
|
8月前
|
自然语言处理 监控 搜索推荐
佛萨奇2.0/3.0Metaforce原力元宇宙系统开发步骤逻辑丨方案项目丨案例设计丨成熟技术丨源码功能
佛萨奇(VoZaChi)是一个虚拟助手系统,其发展至2.0和3.0版本会有一些特定需求和逻辑
|
存储 安全 算法
Free自由协议dapp流动性挖矿系统开发说明及流程
区块链是比特币的一个重要概念,是利用块链式数据结构来验证与存储数据;利用分布式节点共识算法,来生成和更新数据;利用密码学的方式,保证数据传输和访问的安全;利用由自动化脚本代码组成的智能合约,来编程和操作数据的一种全新的分布式基础架构与计算方式。
NFT卡牌游戏链游系统开发(开发方案)/详情规则/成熟技术/设计界面/案例项目/源码程序
NFT (Non Homogeneous Token) card chain game refers to a game based on blockchain technology where NFT is used as the card in the game. NFT is a unique and non interchangeable digital asset that can represent various virtual cards, props, or characters in the game.
|
存储 安全 区块链
区块链游戏系统开发(开发详细)/案例开发/设计功能/逻辑方案/源码平台
  区块链游戏系统开发是一个复杂而精密的过程。首先,需要进行需求分析和规划,确定游戏系统的功能和特性。然后,进行技术选型和架构设计,选择适合的区块链平台和开发工具。接下来,进行系统的搭建和编码,实现游戏逻辑和用户交互功能。最后,进行测试和优化,确保系统的稳定性和性能。
|
区块链 数据安全/隐私保护 安全
swap去中心化交易所兑换池系统开发需求项目丨方案逻辑丨源码案例丨成熟技术丨源码版
  未来区块链交易所的发展趋势是金融衍生品交易。随着加密货币市场的不断发展和壮大,加密货币衍生品的市场也越来越大,区块链交易所需要支持加密货币衍生品的交易,满足市场需求。
|
算法 机器人 区块链
数字货币量化机器人系统开发(项目案例)/功能说明/逻辑方案/源码平台
  简单地说,量化交易机器人就是能够自动执行交易策略的交易软件。它借助于计算机技术和数学模型,对市场行情进行分析预测,并根据程序设定的规则和条件自动执行交易策略,完成交易操作。Compared with traditional manual trading,quantitative trading robots have faster trading speed,lower transaction costs,and higher trading efficiency.

热门文章

最新文章