news 2026/2/12 10:42:54

阿里验证码Web和H5客户端V3架构接入鼠标拖拽滑块离开对话框释放鼠标时一直处于验证中问题

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
阿里验证码Web和H5客户端V3架构接入鼠标拖拽滑块离开对话框释放鼠标时一直处于验证中问题

Web和H5客户端V3架构接入:

现象:鼠标拖拽滑块离开对话框释放鼠标时一直处于验证中,没有触发验证。

分析:V3版本问题,V2无该问题。初步定位是因为V3滑块离开滑块弹框范围时释放鼠标,没有触发mouseup事件,导致插件没有回调验证函数;

解决思路:尝试拖拽在滑块框外面时,手动触发校验,分析getInstance方法返回实列没有对外提供方法触发校验;

思考:手动触发滑块按钮事件,看是不能触发插件的校验回调,通过JS获取滑块dom节点,研究mousedown,mosemove,mouseup, click事件,发现调用滑块的click事件可用触发插件校验回调函数(返回账号密码等信息),效果满足。

结合react工程代码整理如下:

// 获取验证码实例 const getInstance = useCallback( (instance: ICaptchaInstance) => { // 验证码弹窗Dom const sliderElement = document.getElementById('aliyunCaptcha-sliding-slider'); // 滑块按钮Dom const modalElement = document.getElementById('vnnox-care-captcha-modal'); // 先清理上一次注册的事件,避免重复绑定 if (dragCleanupRef.current) { dragCleanupRef.current(); dragCleanupRef.current = null; } if (sliderElement && modalElement) { const handleMouseDown = () => { isDraggingRef.current = true; }; const handleMouseMove = () => { // 仅用于标记拖拽过程,不在此处触发点击 if (!isDraggingRef.current) return; }; const handleMouseUp = (event: MouseEvent) => { if (!isDraggingRef.current) return; isDraggingRef.current = false; const rect = modalElement.getBoundingClientRect(); const { clientX, clientY } = event; const isInside = clientX >= rect.left && clientX <= rect.right && clientY >= rect.top && clientY <= rect.bottom; // 当拖拽结束(mouseup)时,如果鼠标位置已滑出父元素区域,则触发一次点击 if (!isInside) { // 添加到setTimeout中调用click,解决因调用click验证码弹框消失问题 setTimeout(()=>{ sliderElement.click(); }); } }; sliderElement.addEventListener('mousedown', handleMouseDown); window.addEventListener('mousemove', handleMouseMove); window.addEventListener('mouseup', handleMouseUp); dragCleanupRef.current = () => { sliderElement.removeEventListener('mousedown', handleMouseDown); window.removeEventListener('mousemove', handleMouseMove); window.removeEventListener('mouseup', handleMouseUp); }; } . . . }, [getErrorMessage, handleErrorWithDebounce] );
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/11 20:52:47

Ofd2Pdf使用教程:从OFD到PDF的快速转换指南

Ofd2Pdf使用教程&#xff1a;从OFD到PDF的快速转换指南 【免费下载链接】Ofd2Pdf Convert OFD files to PDF files. 项目地址: https://gitcode.com/gh_mirrors/ofd/Ofd2Pdf Ofd2Pdf是一款专业的OFD格式转换工具&#xff0c;能够高效地将OFD文件转换为PDF格式&#xff0…

作者头像 李华
网站建设 2026/2/9 9:01:44

从信息到意义——为什么说整合信息论是一种关于意义的理论

导语自香农提出信息论以来&#xff0c;“信息”被成功地数学化&#xff0c;却被刻意与“意义”分离&#xff1b;这使得传统信息论能够解决通信工程问题&#xff0c;却无法解释主观体验与意识。从探讨大脑如何生成意义的角度出发&#xff0c;整合信息论&#xff08;IIT&#xff…

作者头像 李华
网站建设 2026/2/9 9:29:03

避免空白字符的To-Do应用开发

在开发一个简单的To-Do列表应用时&#xff0c;处理用户输入是其中一个重要的环节。特别是当用户不小心输入了空白字符&#xff08;比如空格&#xff09;后&#xff0c;我们不希望这些无效的输入被添加到列表中。本文将详细介绍如何在React应用中实现这一功能。 问题描述 假设我…

作者头像 李华
网站建设 2026/2/4 4:10:44

超越-env-一份成熟的应用程序配置指南

GitHub 主页 关于Hyperlane框架 Hyperlane 是一个轻量级、高性能、跨平台的 Rust HTTP 服务器框架&#xff0c;构建于 Tokio 异步运行时之上。 核心特性 性能表现&#xff1a;Keep-Alive开启324,323 QPS&#xff0c;关闭51,031 QPS | 统一API&#xff1a;HTTP、WebSocket、…

作者头像 李华
网站建设 2026/2/9 14:03:00

一文搞懂爬山算法!!!

文章目录 全文脉络 第一部分:爬山算法的核心思想 1.1 算法思想与自然类比 1.2 核心特点与适用场景 第二部分:算法流程与变种 2.1 关键步骤分解 2.2 常用变种策略 第三部分:Python实现与实战应用 3.1 实例一:求解函数极值 完整代码与注释 运行结果与分析 3.2 实例二:解决旅…

作者头像 李华
网站建设 2026/2/11 14:11:18

【金猿产品展】纷享销客——用智能科技和行业智慧赋能企业增长

纷享销客产品该大数据类产品由纷享销客投递并参与金猿组委会数据猿上海大数据联盟共同推出的《2025中国大数据产业年度创新服务产品——十年标杆产品》榜单/奖项评选。大数据产业创新服务媒体——聚焦数据 改变商业在第四次工业革命浪潮席卷全球的背景下&#xff0c;AI技术正以…

作者头像 李华