当前位置: 首页 > 知识库问答 >
问题:

前端 - 为什么useWheel不能工作而v-wheel可以?

祁通
2024-06-06

我在vue3项目中使用了 '@vueuse/gesture' 的useWheel函数来帮助监听滚轮在一个元素上的滑动,但我发现指令能生效,而Composable的写法却不生效,无法触发wheelHandler回调。

我在调用useWheel之前也log了 workspaceArea.value是有值的,正常的。
是我的代码写的有问题吗?还是库的bug?

function wheelHandler ({ movement: [x, y], wheeling }) {  console.log(x); // 没打印}// Composable usageuseWheel(wheelHandler, {  domTarget: workspaceArea.value,})<div ref="workspaceArea"  v-wheel="wheelHandler"> // 指令有用,不加这个的话就无法打印

共有3个答案

谢泽语
2024-06-06

useWheel(wheelHandler, {
// domTarget: workspaceArea.value, <- 丢失响应式
domTarget: workspaceArea,
})

韩鸿
2024-06-06

感觉像是注册时机的问题? useWheel 函数放到 onMounted 里面再试试?

<template>  <!-- Directive usage -->  <div ref="demo" v-wheel="wheelHandler" /></template><script setup>const demo = ref()// Find more about `set()` on the "Motion Integration" pageconst wheelHandler = ({ movement: [x, y], wheeling }) => {  if (!wheeling) {    set({ x: 0, y: 0 })    return  }  set({ y, x })}// Composable usageuseWheel(wheelHandler, {  domTarget: demo,})</script>
  • Wheel | @vueuse/gesture
宇文元明
2024-06-06

useWheelv-wheel 都是 @vueuse/gesture 库中提供的用于处理滚轮事件的工具,但它们的使用方式和场景有所不同。

useWheel 是一个 Composable 函数,它允许你以更灵活的方式在 Vue 组件中处理滚轮事件。然而,它不会自动将事件监听器附加到 DOM 元素上。你需要手动将返回的解除绑定函数与组件的生命周期钩子关联起来,以确保事件监听器在组件销毁时正确移除。

另一方面,v-wheel 是一个 Vue 指令,它会自动处理这些细节,并将事件监听器附加到绑定的 DOM 元素上。

如果 useWheel 没有按预期工作,而 v-wheel 正常工作,这可能是由于以下几个原因:

  1. 事件监听器未正确绑定:在使用 useWheel 时,你需要确保返回的解除绑定函数在组件销毁时被调用。否则,可能会导致事件监听器未正确附加到 DOM 元素,或在组件销毁后仍然存在。
  2. domTarget 引用问题:确保 workspaceArea.value 是一个有效的 DOM 元素引用。如果它未正确引用,useWheel 将无法将事件监听器附加到正确的元素上。
  3. 库版本或用法问题:确保你使用的 @vueuse/gesture 库版本与你的 Vue 3 项目兼容,并且你按照文档中的说明正确使用了 useWheel

下面是一个正确使用 useWheel 的例子,展示了如何将解除绑定函数与 Vue 组件的生命周期钩子关联:

<template>  <div ref="workspaceArea">    <!-- ... 其他内容 ... -->  </div></template><script>import { ref, onUnmounted } from 'vue';import { useWheel } from '@vueuse/gesture';export default {  setup() {    const workspaceArea = ref(null);    const { stop } = useWheel(      ({ movement: [x, y], wheeling }) => {        console.log(x);      },      {        domTarget: workspaceArea.value,      }    );    onUnmounted(stop); // 确保在组件销毁时停止监听    return {      workspaceArea,    };  },};</script>

在这个例子中,stop 函数是从 useWheel 返回的,它用于停止事件监听。我们使用 Vue 的 onUnmounted 钩子来确保在组件卸载时调用 stop 函数,从而避免内存泄漏。

如果上述方法仍然无法解决问题,可能需要进一步检查你的代码,或者考虑查看 @vueuse/gesture 的相关 issue,以确定是否为库的问题或特定环境下的bug。此外,查阅库的文档和更新日志也是一个好习惯,以了解是否有任何已知的兼容性问题或更新说明。

 类似资料:
  • 问题内容: 我正在尝试向div添加ajax响应(它是带有表,表单等的HTML代码)。 在FF中工作完美,但在IE中却给了我一个未知的错误。 我尝试了很多东西,但是只有当我添加jQuery并在要插入代码的div上运行该方法时,它才起作用。 有人在乎解释为什么这样做有效,而不是简单吗?我尝试查看代码,但我想我不是JS的佼佼者,因为我不了解它在做什么。 问题答案: IE 有 多个 文档(pre | ta

  • 使用scandir()函数时,我收到以下php警告: Scandir无法打开目录:公共html/page2中不允许操作。php在线3 第2页。php 我想使用这个功能来打印我的根文件夹的文件和子目录,但它不工作。 有人知道怎么修吗?

  • 我正在使用Java NIO,由于某种原因,我无法获得files.isHidden()来返回正确的布尔值。程序只是检查目录是否隐藏,如果隐藏,则使其可见,如果不隐藏,则使其隐藏。这就是我所拥有的: 它继续返回false并隐藏目录,尽管目录被隐藏。下面的代码使用旧的File类和Path类可以很好地工作。

  • 问题内容: 在Python中,用于初始化不可变类型,通常用于初始化可变类型。如果将其从语言中删除,该怎么办(轻松)? 例如, 可以这样重写: 为澄清问题的范围:这不是一个问题关于如何以及是使用或它们之间有什么区别。这是一个问题,如果从语言中删除将会发生什么。有什么坏事吗?事情会变得很难或不可能吗? 问题答案: 您可以在中进行的所有操作都可以在中完成。 那么,为什么要使用? 因为您不必将实例存储在变

  • 因此,我正在从事一个项目,该项目从互联网上的许多不同来源抓取和收集数据,并根据每个来源的特征使用许多不同的方法。 最近添加的是一个web调用,它返回以下XML作为响应: 在使用Microsoft XML v6.0成功处理类似情况后,我尝试了以下方法: 这应该返回,但它返回。确实如下: 返回True,这意味着 我在某个地方读到,早期绑定可能会导致问题,因此我也尝试了以下方法: 结果仍然是一样的。 切

  • 会有什么问题? 我的web包设置:

  • 我一直在用SceneBuilder 9.0.1在IntelliJ上做一个项目。昨天,在NetBeans 8上做了一个小型项目,12之后由于某种原因没有启动新项目。一旦关闭所有内容并打开IntelliJ项目,fxml文档就无法使用SceneBuilder打开。对于这个问题,需要注意以下几点: 我使用的是9.0.1版,尽管v15也有同样的问题, 其中一个fxml文件的示例如下: 请帮助。

  • chrome浏览器 onclick链接 O:https://www.w3schools.com窗口打开 X:about:空白窗口打开