Vue 3获取DOM元素的大小以及相对于视口的位置的getBoundingClientRect属性

本文主要是介绍Vue 3获取DOM元素的大小以及相对于视口的位置的getBoundingClientRect属性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Vue 3中,可以使用ref来获取DOM元素的getBoundingClientRect属性。
如果元素已挂载,我们使用 getBoundingClientRect 方法来获取元素的位置和大小信息。这个方法返回一个对象,其中包含了 left、top、right、bottom 等属性,这些属性表示元素相对于其最近的滚动祖先(通常是视口)的位置。
这里是一个简单的例子:

<template><div ref="boxRef">Hello World</div>
</template><script setup>
import { ref, onMounted } from 'vue';const boxRef = ref(null); //创建一个响应式引用boxRef,它将指向div元素//在onMounted钩子中,我们确保当组件挂载后获取这个元素的getBoundingClientRect属性。这个属性包含了元素的大小以及相对于视口的位置。
onMounted(() => {if (boxRef.value) {const rect = boxRef.value.getBoundingClientRect();console.log(rect);}
});
</script>

如果你想要监听元素上的右键点击事件,并获取该元素的位置,你可以使用@contextmenu.prevent来监听右键点击事件,并使用getBoundingClientRect方法来获取元素的位置。
这里是如何实现的一个例子:

<template><div ref="myElement" @contextmenu.prevent="handleRightClick">右键点击我</div>
</template><script setup>
import { ref } from 'vue';const myElement = ref(null);function handleRightClick(event) {if (myElement.value) {//获取了元素的位置信息rect,它包含了元素相对于视口的位置和大小。//使用event.clientX和event.clientY来获取鼠标指针相对于浏览器视口的位置,并从中减去元素的位置,从而得到鼠标指针相对于元素左上角的位置。const rect = myElement.value.getBoundingClientRect();const x = event.clientX - rect.left;const y = event.clientY - rect.top;console.log('元素位置:', rect);console.log('相对于元素的点击位置:', { x, y });// 阻止浏览器默认上下文菜单显示event.preventDefault();
//额外例子 如果你获取offsetWidth值 如下:const offsetWidth = myElement.value.offsetWidth;console.log('元素的offsetWidth:', offsetWidth);}
}
</script>

请注意,getBoundingClientRect返回的位置是相对于视口的,而不是相对于文档的。如果你需要相对于整个文档的位置,你需要将视口滚动偏移量考虑进去。这通常涉及到使用window.scrollX和window.scrollY(或者document.documentElement.scrollLeft和document.documentElement.scrollTop)来获取这些值,并将它们加到rect.left和rect.top上。

在Vue 3中,如果你有一个通过v-for循环渲染的元素列表,并且 你想要在右键点击这些元素时获取它们的位置,你可以为每个元素添加一个唯一的引用,并在事件处理函数中通过该引用获取元素的位置。

以下是一个示例,展示了如何为循环渲染的元素添加右键点击事件,并获取它们的位置:

<template><div><divv-for="(item, index) in items":key="item.id":ref="`itemRef${index}`"@contextmenu.prevent="handleRightClick(index, $event)"style="margin-bottom: 10px; padding: 10px; background-color: lightgray;">Item {{ item.id }}</div></div>
</template><script setup>
import { ref, onMounted } from 'vue';const items = ref([{ id: 1 },{ id: 2 },{ id: 3 },// ...其他项目
]);const itemRefs = ref({}); // 存储所有项目的引用onMounted(() => {// 假设你需要在组件挂载后做一些事情,比如为动态生成的ref添加事件监听器等
});function handleRightClick(index, event) {const refName = `itemRef${index}`;const itemElement = itemRefs.value[refName];if (itemElement) {const rect = itemElement.getBoundingClientRect();console.log('元素位置:', rect);console.log('相对于元素的点击位置:', {x: event.clientX - rect.left,y: event.clientY - rect.top});}
}
</script>

在这个例子中,我们为每个循环渲染的元素创建了一个唯一的引用名称,通过拼接字符串"itemRef"和当前元素的索引index来实现。然后,在handleRightClick函数中,我们使用这个引用名称来获取对应的DOM元素,并调用getBoundingClientRect来获取元素的位置。

请注意,itemRefs是一个响应式对象,用于存储所有动态生成的ref。当Vue渲染这些元素时,每个元素的ref都会被自动添加到itemRefs对象中,并且可以使用它们的引用名称来访问。

此外,@contextmenu.prevent指令用于监听右键点击事件,并阻止默认的上下文菜单显示。$event是Vue的特殊变量,代表原生DOM事件对象,你可以用它来获取鼠标的位置等信息。

请确保你的项目已经正确设置,并且你正在使用Vue 3的Composition API语法。如果你的项目配置有所不同,可能需要进行一些调整来使这段代码正常工作。

这篇关于Vue 3获取DOM元素的大小以及相对于视口的位置的getBoundingClientRect属性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1037397

相关文章

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Nginx实现前端灰度发布

《Nginx实现前端灰度发布》灰度发布是一种重要的策略,它允许我们在不影响所有用户的情况下,逐步推出新功能或更新,通过灰度发布,我们可以测试新版本的稳定性和性能,下面就来介绍一下前端灰度发布的使用,感... 目录前言一、基于权重的流量分配二、基于 Cookie 的分流三、基于请求头的分流四、基于请求参数的分

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

基于Canvas的Html5多时区动态时钟实战代码

《基于Canvas的Html5多时区动态时钟实战代码》:本文主要介绍了如何使用Canvas在HTML5上实现一个多时区动态时钟的web展示,通过Canvas的API,可以绘制出6个不同城市的时钟,并且这些时钟可以动态转动,每个时钟上都会标注出对应的24小时制时间,详细内容请阅读本文,希望能对你有所帮助...

HTML5 data-*自定义数据属性的示例代码

《HTML5data-*自定义数据属性的示例代码》HTML5的自定义数据属性(data-*)提供了一种标准化的方法在HTML元素上存储额外信息,可以通过JavaScript访问、修改和在CSS中使用... 目录引言基本概念使用自定义数据属性1. 在 html 中定义2. 通过 JavaScript 访问3.

CSS模拟 html 的 title 属性(鼠标悬浮显示提示文字效果)

《CSS模拟html的title属性(鼠标悬浮显示提示文字效果)》:本文主要介绍了如何使用CSS模拟HTML的title属性,通过鼠标悬浮显示提示文字效果,通过设置`.tipBox`和`.tipBox.tipContent`的样式,实现了提示内容的隐藏和显示,详细内容请阅读本文,希望能对你有所帮助... 效

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

浅析Python中的绝对导入与相对导入

《浅析Python中的绝对导入与相对导入》这篇文章主要为大家详细介绍了Python中的绝对导入与相对导入的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1 Imports快速介绍2 import语句的语法2.1 基本使用2.2 导入声明的样式3 绝对import和相对i

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值