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

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

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

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

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

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

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

javascript 复制代码
  // 获取验证码实例
  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]
  );
相关推荐
双翌视觉1 小时前
高精度视觉对位实现键盘线路薄膜定位纠偏
数码相机·计算机外设
今夕资源网9 小时前
windows11无法启用投屏功能 无线显示器无法添加可选功能 解决办法 Miracast修复脚本
windows·计算机外设·miracast·系统修复·无线显示器·投屏功能·投屏功能无法添加
人工智能导论实践课1 天前
从零到一:用 ROS Noetic 搭建可键盘控制的 Gazebo 小车模型
计算机外设
站长工具箱1 天前
鼠标在线测试工具:全维度检测鼠标性能,本地处理更安全
测试工具·计算机外设
开开心心就好1 天前
免费轻量级PDF阅读器,打开速度快
windows·计算机视觉·visualstudio·pdf·计算机外设·excel·myeclipse
春日见2 天前
Matlab快速入门 基础语法教学
java·开发语言·驱动开发·matlab·docker·计算机外设
Saniffer_SH2 天前
【高清视频】AI服务器调试利器:PCIe功耗分析设备 Quarch PAM 深度解析
网络·人工智能·驱动开发·嵌入式硬件·测试工具·计算机外设·压力测试
Never_Satisfied2 天前
在JavaScript / HTML中,监听鼠标滚动事件
javascript·html·计算机外设
触想工业平板电脑一体机3 天前
【触想智能】工业触摸屏显示器的主要特点以及其应用领域分析
计算机外设
TESmart碲视4 天前
Mac+PC双系统如何共享双屏?KVM切换器选购的5个关键指标|TESmart用户真实体验复盘
macos·计算机外设·kvm切换器·tesmart·双屏kvm切换器·碲视