Vue3获取元素DOM的两种方法
Vue3中获取dom的方法有两种 : ref模板引用和传统方法
1.ref模板引用
模板引用是官方提出的方法,请看下面的例子:
<template>
<canvas ref="solarCanvas" id="solar" width="1300" height="900"></canvas>
</template>
<script setup>
import { onMounted, ref } from 'vue'
const solarCanvas = ref(null)
onMounted(() => {
console.log(solarCanvas.value)//HTMLCanvasElement{...}
})
</script>这里要注意的是只可以在组件挂载后才能访问模板引用 ,上面的例子中onMounted执行时组件已经挂载了 , 所以打印solarCanvas有值。
<template>
<canvas ref="solarCanvas" id="solar" width="1300" height="900"></canvas>
</template>
<script setup>
import { onMounted, ref } from 'vue'
const solarCanvas = ref(null)
console.log(solarCanvas.value)//null
</script>反之,如果这样写打印出来的值就为null,因为此时组件还没有挂载完成。
2.传统方法
传统方法就是指使用JS原生的获取dom的方法,如:getElementById、querySelector等。请看下面的例子:
<template>
<canvas id="solar" width="1300" height="900"></canvas>
</template>
<script setup>
import { nextTick, onMounted, ref } from 'vue'
onMounted(() => {
const canvas = document.getElementById('solar')
console.log(canvas)//HTMLCanvasElement{...}
})
</script>拓展:Vue3获取DOM节点的几种方式
1 .原生js获取 DOM 节点:
document.querySelector(选择器) document.getElementById(id选择器) document.getElementsByClassName(class选择器) ....
2. vue2中获取当前组件的实例对象:
因为每个 vue 的组件实例上,都包含一个 $refs 对象,里面存储着对应的 DOM 元素或组件的引用。所以在默认情况下, 组件的 $refs 指向一个空对象 。
可以先在组件上加上 ref="名字" ,然后通过 this.$refs.名字 获取相应元素并进行操作。
<template>
<div class="box">
<h1 ref="divDom">这是一个测试样例</h1>
<button ref="but">按钮</button>
</div>
</template>
<script>
export default {
data() {
return {
}
},
methods: {
showThis(){
// h1的实例对象
console.log(this);
this.$refs.divDom.style.color='yellow'
//引用到组件的实例之后,也可以调用组件上的 methods方法
this.$refs.but.click();
},
},
}
</script>3.vue3中获取当前组件的实例对象:
在Vue3框架里面是解除了this这个对象,所以无法使用this.$refs的方式获取自定义组件 ref 的DOM节点。
但是vue3中自带了能返回当前组件实例对象的函数 getCurrentInstance,通过该函数获取对象节能看到该对象包含界面中的refs。
<template>
<div ref="divDom"></div>
</template>
<script setup>
import { ref, getCurrentInstance } from 'vue';
const divDom = ref(null);
onMounted(()=>{
console.log('获取dom元素',divDom)
})
// 获取页面的实例对象
const pageInstance = getCurrentInstance();
// 获取dom节点对象
const tagDomObj = pageInstance.refs.divDom;
</script>3.结论
在Vue3当获取DOM的方法主要有两个:模板引用和传统方法。
但需要注意的是,无论使用哪种方法都只有在组件挂载之后才能获取到DOM,可以使用watch或onMounted确保自己已经获取到DOM。
到此这篇关于Vue3获取元素DOM的两种方法的文章就介绍到这了,更多相关Vue3获取DOM内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue-treeselect无法点击问题(点击无法出现拉下菜单)
这篇文章主要介绍了vue-treeselect无法点击问题(点击无法出现拉下菜单),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-04-04
Vue3 openlayers加载瓦片地图并手动标记坐标点功能
这篇文章主要介绍了 Vue3 openlayers加载瓦片地图并手动标记坐标点功能,我们这里用vue/cli创建,我用的node版本是18.12.1,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下2024-04-04
vue中element-ui表格缩略图悬浮放大功能的实例代码
element-ui界面非常简洁和美观,提供的组件可以满足绝大多数的应用场景,当表格中显示了图片的缩略图时,想要鼠标浮动在缩略图上时放大图片的效果,该如何实现呢?下面小编通过实例代码给大家介绍vue中element-ui表格缩略图悬浮放大功能,一起看看吧2018-06-06


最新评论