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

相关文章

SpringBoot整合mybatisPlus实现批量插入并获取ID详解

《SpringBoot整合mybatisPlus实现批量插入并获取ID详解》这篇文章主要为大家详细介绍了SpringBoot如何整合mybatisPlus实现批量插入并获取ID,文中的示例代码讲解详细... 目录【1】saveBATch(一万条数据总耗时:2478ms)【2】集合方式foreach(一万条数

python获取网页表格的多种方法汇总

《python获取网页表格的多种方法汇总》我们在网页上看到很多的表格,如果要获取里面的数据或者转化成其他格式,就需要将表格获取下来并进行整理,在Python中,获取网页表格的方法有多种,下面就跟随小编... 目录1. 使用Pandas的read_html2. 使用BeautifulSoup和pandas3.

SpringBoot UserAgentUtils获取用户浏览器的用法

《SpringBootUserAgentUtils获取用户浏览器的用法》UserAgentUtils是于处理用户代理(User-Agent)字符串的工具类,一般用于解析和处理浏览器、操作系统以及设备... 目录介绍效果图依赖封装客户端工具封装IP工具实体类获取设备信息入库介绍UserAgentUtils

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

HTML5中的Microdata与历史记录管理详解

《HTML5中的Microdata与历史记录管理详解》Microdata作为HTML5新增的一个特性,它允许开发者在HTML文档中添加更多的语义信息,以便于搜索引擎和浏览器更好地理解页面内容,本文将探... 目录html5中的Mijscrodata与历史记录管理背景简介html5中的Microdata使用M

html5的响应式布局的方法示例详解

《html5的响应式布局的方法示例详解》:本文主要介绍了HTML5中使用媒体查询和Flexbox进行响应式布局的方法,简要介绍了CSSGrid布局的基础知识和如何实现自动换行的网格布局,详细内容请阅读本文,希望能对你有所帮助... 一 使用媒体查询响应式布局        使用的参数@media这是常用的

HTML5表格语法格式详解

《HTML5表格语法格式详解》在HTML语法中,表格主要通过table、tr和td3个标签构成,本文通过实例代码讲解HTML5表格语法格式,感兴趣的朋友一起看看吧... 目录一、表格1.表格语法格式2.表格属性 3.例子二、不规则表格1.跨行2.跨列3.例子一、表格在html语法中,表格主要通过< tab

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的