当前位置: 首页 > news >正文

阿里验证码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] );
http://www.cnnetsun.cn/news/96882.html

相关文章:

  • Ofd2Pdf使用教程:从OFD到PDF的快速转换指南
  • 从信息到意义——为什么说整合信息论是一种关于意义的理论
  • 避免空白字符的To-Do应用开发
  • 超越-env-一份成熟的应用程序配置指南
  • 一文搞懂爬山算法!!!
  • 【金猿产品展】纷享销客——用智能科技和行业智慧赋能企业增长
  • Motrix浏览器扩展:重新定义你的下载体验
  • 20、量子计算中的线性代数基础
  • LobeChat知识点讲解生成器开发
  • asio的socket创建与连接的基础实现和与C风格的socket网络通信的对比
  • Locale Emulator终极指南:系统区域模拟与多语言软件解决方案
  • LobeChat数据库存储机制解析:对话记录保存在哪里?
  • Obsidian主题配置终极指南:轻松打造个性化知识管理界面
  • OBS-VST插件终极指南:5分钟打造专业直播音效
  • LobeChat差评挽回话术建议
  • 3、量子力学的奇妙世界:从争议到多元解读
  • LobeChat国庆节爱国主题文案
  • 基于LabVIEW与三菱FX的MC协议通信:封装多态VI,支持布尔量读写及整形、长整型读取与布...
  • LobeChat机器学习模型解释生成器
  • 淘宝Claude服务价格优势与套餐模式解析
  • LobeChat未读消息角标文案
  • LobeChat能否集成地震预警?灾害应急响应智能通知系统
  • 原子指标计算实现方案详解 | qData 数据中台商业版 · 指标平台
  • LobeChat法律咨询场景适用性评估
  • LobeChat安全策略解读:保障数据不出内网的关键设置
  • LobeChat WebSocket通信机制剖析:实时对话是如何实现的?
  • 公司网站wordpress主题推荐
  • 金融从业者福音:LobeChat搭建合规AI分析助手
  • LobeChat科技新闻深度解读
  • LinkedIn职业建议:LobeChat撰写个人简介