Vue组件:模板引用ref属性的使用

Vue 组件系列文章:

《Vue组件:创建组件、注册组件、使用组件》

《Vue组件:使用Prop实现父组件向子组件传递数据》

[《Vue组件:使用emit()方法监听子组件事件》](https://blog.csdn.net/pan_junbiao/article/details/141963178 "《Vue组件:使用emit()方法监听子组件事件》")

《Vue组件:插槽》

《Vue组件:混入》

《Vue组件:动态组件、缓存组件、异步组件》

《Vue组件:依赖注入provide和inject的使用》

《Vue组件:模板引用ref属性的使用》

虽然 Vue 的声明性渲染模型为你抽象了大部分对 DOM 的直接操作,但在某些情况下,我们仍然需要直接访问底层 DOM 元素。要实现这一点,我们可以使用特殊的 ref 属性。

html 复制代码
<template>
    <!-- 第一步:给 DOM 元素,添加 ref 属性 -->
    搜索:<input ref="search" type="text" />
</template>

挂载结束后引用都会被加载在 this.$refs 之上。

html 复制代码
<template>
    <!-- 第一步:给 DOM 元素,添加 ref 属性 -->
    搜索:<input ref="search" type="text" />
</template>

<script>
export default {
    mounted() {
        //第二步:使用 this.$refs 获取 DOM 元素输入框,并让输入框自动获取焦点
        this.$refs.search.focus();
    }
}
</script>

**【实例】**使用 ref 获取 DOM 元素并赋值。

html 复制代码
<template>
    <fieldset>
        <legend>组件</legend>
        <!-- 第一步:给 DOM 元素,添加 ref 属性 -->
        <h3 ref="title">标题名称</h3>
        <p>博客信息:<input ref="blogName" type="text" /></p>
        <p>博客地址:<input ref="blogUrl" type="text" /></p>
    </fieldset>
</template>

<script>
export default {
    //说明:mounted()生命周期钩子,在 DOM 文档渲染完毕之后进行调用。
    mounted() {
        //第二步:使用 this.$refs 获取 DOM 元素,并赋值内容
        this.$refs.title.innerHTML = '使用 ref 获取 DOM 元素';
        this.$refs.blogName.value = '您好,欢迎访问 pan_junbiao的博客';
        this.$refs.blogUrl.value = 'https://blog.csdn.net/pan_junbiao';
    }
}
</script>

<style scoped>
input {
    width: 300px;
    padding: 3px;
    font-size: 16px;
}
</style>

执行结果:

相关推荐
蓝帆傲亦7 小时前
前端性能极速优化完全指南:从加载秒开体验到丝滑交互
前端·交互
鱼毓屿御8 小时前
如何给用户添加权限
前端·javascript·vue.js
JustHappy8 小时前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
何中应8 小时前
nvm安装使用
前端·node.js·开发工具
xixixin_8 小时前
【JavaScript 】从 || 到??:JavaScript 空值处理的最佳实践升级
开发语言·javascript·ecmascript
Java新手村8 小时前
基于 Vue 3 + Spring Boot 3 的 AI 面试辅助系统:实时语音识别 + 大模型智能回答
vue.js·人工智能·spring boot
雯0609~8 小时前
hiprint:实现项目部署与打印3-vue版本-独立出模板设计与模板打印页面
前端·vue.js·arcgis
杜子不疼.8 小时前
【Linux】教你在 Linux 上搭建 Web 服务器,步骤清晰无门槛
linux·服务器·前端
belldeep8 小时前
python:用 Flask 3 , mistune 2 和 mermaid.min.js 10.9 来实现 Markdown 中 mermaid 图表的渲染
javascript·python·flask
凉辰8 小时前
使用uni.createInnerAudioContext()播放指定音频(踩坑分享功能)
开发语言·javascript·音视频