热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

反应触发KeyboardEvent

我有一个PIN码字段组件,它只是包装在React.Fragment中的输入的列表。每

我有一个PIN码字段组件,它只是包装在React.Fragment中的输入的列表。每次按下一个键,它将聚焦下一个输入。当我到达最后一个输入时,我想触发一个列表以将下一个控制器聚焦在组件之外(输入,按钮,链接等)。我试图调度KeyboardEvent,但不起作用:

const evt = new KeyboardEvent("keydown",{
...
code: "Tab",key: "Tab",})
lastInput.dispatchEvent(evt)

有什么主意吗?

源代码:https://github.com/soywod/react-pin-field
演示:https://react-pin-field.soywod.me/


我想这会解决您的问题-在重新渲染组件时,触发您要聚焦的组件外部的输入元素的鼠标单击事件。

,

根据此answer,浏览器安全模型将停止您模拟Tab键的按下。

作为替代方案,您可以在组件中添加nextFocusId属性,并使用该属性将光标移动到document.getElementById().focus()

,

您可以尝试在元素上使用tabindex

,

再考虑一下这一点,如果无法执行制表符,那么如何在当前元素上设置data-focused,然后收集页面上的所有输入元素,并通过data属性找到当前关注的元素,然后,如果我们不是最后一个元素,则关注下一个项目。

const inputs = document.querySelectorAll("button,input,select,textarea")
const len = inputs.length - 1 // ignore last item in array
let i = 0
while( i if (inputs[i++].dataSet.focused) {
inputs[i].focus()
break
}
}

,

为最后一次输入的keypress事件定义监听器

private OnLastInputChange= e => {
const target = e.target;
const keyboardEvent = new KeyboardEvent("keypress",{
bubbles : true,cancelable : true,key : "Tab",shiftKey : false,keyCode : 13
});
target.dispatchEvent(keyboardEvent);
}

keyCode 13代表制表符ASCII码

以及您的渲染方法

<>
...

//<---- the last pin input


,

假设这里有三个主要组件,一个是PIN,另一个是Next,还有一个父组件Parent拥有PIN和Next。


  1. 父项传递一个onLast道具,该道具是PIN的功能,PIN会在到达最后一个输入时在onLast执行。

  2. 父对象将引用转发给Next,Next将引用附加到其可聚焦元素(输入,按钮,链接等)上。

请记住上述条件,现在我们可以按条件将焦点“触发”到“下一步”。例如调用onLast时(通过PIN到达最后一个输入)。通过使用传统的dom API。

https://developer.mozilla.org/en-US/docs/Web/API/HTMLOrForeignElement/focus

ps。通过编程触发键盘事件是可以的,并且它将触发执行适当的事件处理程序。就是如此,您永远都不要期望它会更有效,例如生成文本,移动焦点(Tab键),它们完全是编程无法达到的用户操作。

,

您可以使用父组件作为中介器,以帮助子组件相互通信,就像我在下面草拟的示例一样:
enter link description here

,

您可以使用父组件作为中介者,以帮助子组件彼此通信,就像我在下面草拟的示例一样,与您所做的相同:
sample


推荐阅读
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • PHP中的单例模式与静态变量的区别及使用方法
    本文介绍了PHP中的单例模式与静态变量的区别及使用方法。在PHP中,静态变量的存活周期仅仅是每次PHP的会话周期,与Java、C++不同。静态变量在PHP中的作用域仅限于当前文件内,在函数或类中可以传递变量。本文还通过示例代码解释了静态变量在函数和类中的使用方法,并说明了静态变量的生命周期与结构体的生命周期相关联。同时,本文还介绍了静态变量在类中的使用方法,并通过示例代码展示了如何在类中使用静态变量。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
author-avatar
Jin_木_木_176
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有