码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【taro react】 ---- 常用自定义 React Hooks 的实现【四】之遮罩层


    1. 问题场景

    在实际开发中我们会遇到一个遮罩层会受到多个组件的操作影响,如果我们不采用 redux 之类的全局状态管理,而是选择组件之间的值传递,我们就会发现使用组件的变量来控制组件的显示和隐藏很不方便,更不要说像遮罩层这样一个项目多处使用的公共组件,他的隐藏和显示也只能放到某一个模块的 redux 中,还要解决遮罩层在ScrollView内,会在IOS显示不全,等等bug的问题,可以说烦不胜烦。

    2. 解决办法

    1. 使用当前页面模块的 redux 来管理当前页面中的遮罩层;
    2. 使用 useReducer 来管理当前页面中的遮罩层;
    3. 使用 hook 来实现遮罩层的清除和添加。

    3. 方案分析

    1. 方案一和方案二其实原理都一样,就是将控制遮罩层的变量集中管理,但是缺点也很明显,就是我们需要多少遮罩层,就会创建多少个变量,维护这些变量来控制遮罩层的显示与隐藏。维护多变量控制多遮罩层。
    2. 方案三我采用的是使用一个变量来接收遮罩层,通过改变变量的值来实现遮罩层的显示与隐藏。维护单一变量。

    4. 保存 hook 初始化配置

    1. 在 hook 初始化时,使用 useRef 对初始化配置进行记录;
    2. 防止对 options 改变时,没有及时更新,因此监听 options,发生变化时,对初始化配置进行更新。
      let
    • 相关阅读:
      Multiplexer and Demultiplexer(多路复用器和解复用器)
      正则表达式学习(超详细)
      Vue3.0 vue.js.devtools无法显示Pinia调试工具
      上周热点回顾(4.8-4.14)
      Mysql读写分离
      点云从入门到精通技术详解100篇-基于路侧激光雷达的交通目标感知方法与实现(下)
      ipad触控笔是哪几款?开学季便宜的ipad电容笔推荐
      Linux系统之部署Linux命令大全搜索工具
      怎样提高服务器安全性?45.248.11.x
      VMware ifconfig ip报错解决记录
    • 原文地址:https://blog.csdn.net/m0_38082783/article/details/133742996
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号