我的编程空间,编程开发者的网络收藏夹
学习永远不晚

React onBlur回调中怎么使用document.activeElement返回body

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

React onBlur回调中怎么使用document.activeElement返回body

这篇文章主要讲解了“React onBlur回调中怎么使用document.activeElement返回body”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React onBlur回调中怎么使用document.activeElement返回body”吧!

最开始想实现一个功能,点击img图标后给出购物下拉框CartDropdown,当img及CartDropdown失去焦点时隐藏CartDropdown。

最开始的核心代码如下:

export default function Cart() {const [isCartOpen, setIsCartOpen] = useState(false)function clickHandler() {setIsCartOpen(!isCartOpen)}function closeCartDropdown() {            if(!document.querySelector('#cart').contains(document.activeElement)) {                    setIsCartOpen(false)            }}return (<div id="cart" className="relative" onBlur={closeCartDropdown}><div tabIndex={0} onClick={clickHandler} className='relative hover:-translate-y-0.5 active:translate-y-0 transition-transform cursor-pointer'><img className='h-14' class="lazy" data-src="/class="lazy" data-src/assets/images/shopping_bag.png" alt="shopping bag" /><span className='Z-10 text-2xl font-bold absolute left-1/2 -translate-x-1/2 -translate-y-2/3' style={{top:'70%'}}>4</span></div>{<CartDropdown isCartOpen={isCartOpen}/>}</div>)}

这个版本的代码中在onBlur回调中使用document.activeElement函数想要获取当前聚焦的元素,之后通过判断聚焦的元素是cart组件内的来判断是否需要隐藏cartDropdown,但这里document.activeElement返回的都是body元素。

后面我加入了onFocus函数,并在其中获取document.activeElement却能返回正确的结果,并且是先触发onBlur再触发onFocus函数。这样就可以确定,在之前的元素失去焦点时,onBlur函数被调用,此时没有焦点因此默认给在body上;之后onFocus函数执行,此时新元素获得焦点,因此可以正常获取聚焦结果。

因此在onBlur中想要正确获取聚焦元素,应该在onFocus函数调用后,所以可以使用异步函数来完成这一点。我选取setTimeout来进行异步操作,并且成功在onBlur函数中获取到了正确的document.activeElement值。

function closeCartDropdown() {setTimeout(() => {             if(!document.querySelector('#cart').contains(document.activeElement)) {setIsCartOpen(false)             }        }, 0)}

备注:传统html中blur事件是不能冒泡的,但react中进行了特殊的处理成功模拟了冒泡,因此可以实现子组件失去焦点,调用父组件回调函数的效果。

感谢各位的阅读,以上就是“React onBlur回调中怎么使用document.activeElement返回body”的内容了,经过本文的学习后,相信大家对React onBlur回调中怎么使用document.activeElement返回body这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

React onBlur回调中怎么使用document.activeElement返回body

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

React onBlur回调中怎么使用document.activeElement返回body

这篇文章主要讲解了“React onBlur回调中怎么使用document.activeElement返回body”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React onBlur回调中
2023-07-06

ReactonBlur回调中使用document.activeElement返回body完美解决方案

这篇文章主要介绍了ReactonBlur回调中使用document.activeElement返回body完美解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-16

怎么使用SAFEARRAY返回

这篇文章主要介绍了怎么使用SAFEARRAY返回,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。IDE用的是VC7.1开始都差不多,建立工程,建立COM对象,建立方法: 接口定
2023-06-08

php中怎么使用引用返回

php中怎么使用引用返回,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。说明1、引用返回用于当你想用函数找到引用应该绑定在哪个变量上时。2、将函数的返回与变量绑定起来,这样在
2023-06-20

怎么使用react-activation实现keepAlive支持返回传参

这篇文章主要介绍“怎么使用react-activation实现keepAlive支持返回传参”,在日常操作中,相信很多人在怎么使用react-activation实现keepAlive支持返回传参问题上存在疑惑,小编查阅了各式资料,整理出简
2023-06-30

Linux 中怎么使用Shell函数返回值

这篇文章将为大家详细讲解有关Linux 中怎么使用Shell函数返回值,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1) return 语句shell函数的返回值,可以和其他语言的返回值一样
2023-06-09

怎么使用Fiddler返回mock响应

这篇文章主要介绍“怎么使用Fiddler返回mock响应”,在日常操作中,相信很多人在怎么使用Fiddler返回mock响应问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Fiddler返回mock响应
2023-06-04

怎么使用ABAP代码返回Attachment

这篇文章主要讲解了“怎么使用ABAP代码返回Attachment”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用ABAP代码返回Attachment”吧!在事务码 MM02里为ID为1
2023-06-04

Python中的回调函数怎么使用

本文小编为大家详细介绍“Python中的回调函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python中的回调函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。摘要主要是介绍python 的
2023-07-02

JAVA中使用map返回错误怎么解决

在Java中,当使用Map作为函数的返回值时,可能会遇到一些错误。解决这些错误的方法取决于具体的错误类型。以下是一些常见的错误和解决方法:1. 类型不匹配错误(Type mismatch error):这通常是由于函数的返回类型与实际返回的
2023-08-09

Springboot JPA怎么使用distinct返回对象

这篇文章主要讲解了“Springboot JPA怎么使用distinct返回对象”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Springboot JPA怎么使用distinct返回对象”吧
2023-06-29

jquery回调函数怎么使用

本篇内容介绍了“jquery回调函数怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在jquery中,回调函数就是一个被作为参数传递的
2023-07-04

android webview中使用Java调用JavaScript方法并获取返回值

在android平板上用webview打开一个网页,调用里面的javascript方法,同时相互传参。 网上例子很少啊,基本都不能获取返回值,贴一个自己最后调试完的代码如下: Java:代码如下: protected void onCrea
2022-06-06

C#中怎么用invoke获取返回值

在C#中可以使用Invoke方法来调用一个方法或委托,并获取其返回值。Invoke方法是Delegate类的成员,可以用于调用任何类型的委托。以下是一个使用Invoke方法获取返回值的示例:using System;public cla
2023-10-23

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录