React Flow浏览器默认事件失效问题解决

前情提要

React Flow可以使用滑轮来实现对于该部分区域的放大和缩小,并且自动拦截浏览器默认的滑轮和滑轮+按键组合事件,如:Ctrl+鼠标滑轮事件。那么这就导致在非该区域的地方使用了浏览器默认的滑轮事件且改变了原有页面的大小时,在回到React Flow区域当中,并不能够还原,本文主要针对的是,在不影响当前Flow的功能外,实现对浏览器Ctrl+鼠标滑轮事件的解除拦截效果。

实现流程

首先要明确一个事,React Flow有一个属性可以对浏览器事件进行解除拦截的效果的。这个属性叫

preventScrolling(true:拦截,false:不拦截)

当我们添加这个属性时,可以通过true或false进行对浏览器事件的解绑和绑定的效果,了解了这个那么接下来的事情就好办了。那就是使用动态布尔值来进行对该属性进行处理,并且使用react状态管理、钩子、键盘监听来实现这个对Ctrl+鼠标滑轮的解绑。

实现流程

首先引入相关库:

import React, { useEffect, useState } from 'react';

定义状态变量及函数:

  const [isCtrlPressed, setIsCtrlPressed] = useState(true);  // 状态跟踪 Ctrl 键是否被按下

钩子函数里面放监听,两个监听,一个是ctrl被按下为false,一个是ctrl被释放为true。

 useEffect(() => {
    const handleKeyDown = (event: any) => {
      if (event.ctrlKey) {
        setIsCtrlPressed(false);
      }
    };

    const handleKeyUp = (event: any) => {
      if (!event.ctrlKey) {
        setIsCtrlPressed(true);
      }
    };

    window.addEventListener('keydown', handleKeyDown);
    window.addEventListener('keyup', handleKeyUp);

    return () => {
      window.removeEventListener('keydown', handleKeyDown);
      window.removeEventListener('keyup', handleKeyUp);
    };
  }, []);

最后在ReactFlow组件中添加 preventScrolling={isCtrlPressed}即可,大功告成,收摊回家。

相关推荐

  1. React Flow浏览器默认事件失效问题解决

    2024-04-20 23:30:05       33 阅读
  2. element el-table表格默认勾选toggleRowSelection失效问题

    2024-04-20 23:30:05       41 阅读
  3. 浏览器密码修改,账户Token全部失效解决方案

    2024-04-20 23:30:05       84 阅读
  4. 一次事务失效问题的排查

    2024-04-20 23:30:05       48 阅读
  5. 解决Edge浏览器问题的实用教程

    2024-04-20 23:30:05       47 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-20 23:30:05       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-20 23:30:05       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-20 23:30:05       82 阅读
  4. Python语言-面向对象

    2024-04-20 23:30:05       91 阅读

热门阅读

  1. npm 更改国内镜像的方法

    2024-04-20 23:30:05       38 阅读
  2. 等保测评:网络安全法规框架下的关键合规实践

    2024-04-20 23:30:05       39 阅读
  3. vue--样式绑定--样式切换方法

    2024-04-20 23:30:05       28 阅读
  4. Rust 构建跨平台 GUI 的新选择

    2024-04-20 23:30:05       24 阅读
  5. npm taobao镜像提示 reason: certificate has expired

    2024-04-20 23:30:05       25 阅读
  6. 2-搭建开发环境

    2024-04-20 23:30:05       28 阅读
  7. 自动化_Ansible学习笔记

    2024-04-20 23:30:05       28 阅读
  8. Linux系统安装ansible

    2024-04-20 23:30:05       36 阅读