vue2 使用ref获取并操作DOM元素

本文介绍了在 Vue2 中如何利用 ref 属性来获取并操作 DOM 元素。通过在元素上设置 ref,并在 mounted 生命周期钩子内进行操作,确保在页面渲染完成后修改元素样式,例如将 h3 标签颜色更改为红色。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

获取元素的方法有很多,但在vue中最好用vue提供的方法:ref。
如下图,给想要操作的标签一个属性ref,然后给个值(就是你起的名字,下面要通过这个名字获取,跟原生的方法中class、id一样)
在这里插入图片描述
起好名字后一定要去mounted钩子里操作,因为页面执行到这个钩子的时候已经渲染出DOM了。
如下图:
在这里插入图片描述
那么下载这个h3标签已经改成红色了
在这里插入图片描述

### Vue 3 中使用 `ref` 获取 DOM 元素操作其样式 在 Vue 3 中,可以利用 Composition API 提供的 `ref` 函数来创建响应式的引用对象,通过这些引用访问真实的 DOM 节点及其属性。当目标是在挂载阶段之后修改特定元素的内联样式时,可以在生命周期钩子函数如 `onMounted()` 内部执行相应逻辑。 下面是一个具体的例子展示如何设置和改变某个 div 的背景颜色: ```html <template> <div ref="styledDiv">这个方框的颜色会变化</div> </template> <script> import { ref, onMounted } from 'vue'; export default { setup() { const styledDiv = ref(null); onMounted(() => { // 修改DOM元素的style属性 styledDiv.value.style.backgroundColor = "lightblue"; console.log(styledDiv.value.style); }); return { styledDiv, }; }, }; </script> <style scoped> /* 初始样式 */ div { width: 200px; height: 200px; } </style> ``` 此代码片段展示了如何定义一个名为 `styledDiv` 的引用变量指向模板中的 `<div>` 元素,在组件完成渲染后 (`onMounted`) 更改该元素的背景色为浅蓝色[^1]。 对于更复杂的场景下可能需要等待下一个 DOM 更新周期再读取或更新样式的情况,则可借助于 `nextTick` 方法实现延迟处理: ```javascript import { ref, nextTick } from 'vue'; // ... const changeStyleLater = async () => { await nextTick(); styledDiv.value.style.borderRadius = "50%"; }; changeStyleLater(); ``` 上述方法确保了样式的更改发生在所有的状态变更被应用到 DOM 后立即发生[^2]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

超级码吏

谢谢看官

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值