Vue3中的Refs全解析(附實(shí)戰(zhàn)案例)
前言
今天給大家?guī)硪粋€(gè)超級(jí)實(shí)用的Vue3技巧:如何使用ref實(shí)現(xiàn)DOM元素和組件實(shí)例的引用!如果你在開發(fā)過程中需要直接操作DOM或訪問子組件的方法,那么ref絕對(duì)是你的最佳選擇!話不多說,直接開整~
什么是Ref?
在Vue3中,ref是一個(gè)非常強(qiáng)大的功能,它允許你創(chuàng)建對(duì)DOM元素或子組件實(shí)例的引用。通過這種方式,你可以直接訪問并操作這些元素或組件,而不需要依賴于事件處理或其他間接方法。
核心作用:簡化了直接操作DOM或調(diào)用子組件方法的過程,使得代碼更加直觀易懂!
Refs的核心原理
當(dāng)你在一個(gè)模板中使用ref屬性時(shí),Vue會(huì)將對(duì)應(yīng)的DOM元素或組件實(shí)例存儲(chǔ)到一個(gè)響應(yīng)式的引用對(duì)象中。這個(gè)對(duì)象可以通過this.$refs(在選項(xiàng)API中)或者直接作為變量(在組合API中)來訪問。
- 定義Ref:為DOM元素或組件添加
ref屬性。 - 獲取Ref:通過
this.$refs或ref變量獲取引用。 - 操作Ref:利用獲取到的引用進(jìn)行各種操作,如修改樣式、觸發(fā)事件等。
實(shí)戰(zhàn)案例:基礎(chǔ)用法
假設(shè)我們有一個(gè)場(chǎng)景:想要點(diǎn)擊按鈕后動(dòng)態(tài)改變輸入框的值,并且獲取輸入框當(dāng)前的值。通過ref,我們可以輕松地完成這一任務(wù)!
使用組合式API (Composition API)
父組件
<template>
<div>
<h1>父組件</h1>
<!-- 輸入框 -->
<input type="text" ref="inputField" />
<!-- 按鈕 -->
<button @click="updateInput">更新輸入框值</button>
<!-- 顯示輸入框當(dāng)前值 -->
<p>當(dāng)前輸入框值: {{ inputValue }}</p>
</div>
</template>
<script setup>
import { ref, onMounted } from 'vue';
// 創(chuàng)建一個(gè)ref來引用輸入框
const inputField = ref(null);
// 創(chuàng)建一個(gè)響應(yīng)式變量來保存輸入框的值
const inputValue = ref('');
// 定義更新輸入框值的方法
function updateInput() {
// 修改輸入框的值
inputField.value.value = 'Hello Vue3!';
// 獲取并顯示輸入框的當(dāng)前值
inputValue.value = inputField.value.value;
}
onMounted(() => {
console.log('輸入框已掛載:', inputField.value);
});
</script>
運(yùn)行效果
- 點(diǎn)擊“更新輸入框值”按鈕后,輸入框的值會(huì)被設(shè)置為
'Hello Vue3!',并且頁面上會(huì)顯示當(dāng)前的輸入框值。
使用選項(xiàng)式API (Options API)
如果你想繼續(xù)使用傳統(tǒng)的選項(xiàng)式API,同樣可以輕松實(shí)現(xiàn)相同的功能。
父組件
<template>
<div>
<h1>父組件</h1>
<!-- 輸入框 -->
<input type="text" ref="inputField" />
<!-- 按鈕 -->
<button @click="updateInput">更新輸入框值</button>
<!-- 顯示輸入框當(dāng)前值 -->
<p>當(dāng)前輸入框值: {{ inputValue }}</p>
</div>
</template>
<script>
export default {
data() {
return {
inputValue: ''
};
},
methods: {
updateInput() {
// 修改輸入框的值
this.$refs.inputField.value = 'Hello Vue3!';
// 獲取并顯示輸入框的當(dāng)前值
this.inputValue = this.$refs.inputField.value;
}
},
mounted() {
console.log('輸入框已掛載:', this.$refs.inputField);
}
};
</script>
應(yīng)用場(chǎng)景
動(dòng)態(tài)操作DOM
- 如上述案例所示,
ref可以用來動(dòng)態(tài)地修改DOM元素的屬性或內(nèi)容。
- 如上述案例所示,
訪問子組件方法
- 如果你需要調(diào)用子組件內(nèi)部的方法,可以通過
ref直接獲取子組件實(shí)例并調(diào)用其方法。
- 如果你需要調(diào)用子組件內(nèi)部的方法,可以通過
表單驗(yàn)證
- 在表單驗(yàn)證場(chǎng)景下,可以直接通過
ref訪問表單元素,進(jìn)行即時(shí)驗(yàn)證或提交前的檢查。
- 在表單驗(yàn)證場(chǎng)景下,可以直接通過
動(dòng)畫控制
- 對(duì)于復(fù)雜的動(dòng)畫效果,有時(shí)需要直接操作DOM元素,這時(shí)
ref就派上用場(chǎng)了。
- 對(duì)于復(fù)雜的動(dòng)畫效果,有時(shí)需要直接操作DOM元素,這時(shí)
注意事項(xiàng)
過度依賴ref
- 雖然
ref提供了直接操作DOM的能力,但過度使用可能會(huì)破壞Vue的數(shù)據(jù)驅(qū)動(dòng)理念。盡量保持邏輯在數(shù)據(jù)層面上解決。
- 雖然
生命周期管理
- 確保在組件掛載后再嘗試訪問
ref,否則可能會(huì)導(dǎo)致null引用錯(cuò)誤??梢允褂?code>onMounted鉤子(組合API)或mounted生命周期鉤子(選項(xiàng)API)來進(jìn)行初始化操作。
- 確保在組件掛載后再嘗試訪問
性能考慮
- 直接操作DOM可能會(huì)影響性能,特別是在頻繁更新的情況下。應(yīng)謹(jǐn)慎使用,并盡可能優(yōu)化相關(guān)邏輯。
總結(jié)
通過本文的學(xué)習(xí),我們掌握了ref的基本用法及其應(yīng)用場(chǎng)景,了解了如何在實(shí)際項(xiàng)目中利用該特性簡化DOM操作和組件間通信。無論是簡單的屬性修改還是復(fù)雜的交互邏輯,ref都能讓你的工作更加高效!
希望這篇教程能幫到大家!如果你覺得有用的話,記得點(diǎn)贊收藏并關(guān)注我哦~ ??
如果有任何問題或想法,歡迎在評(píng)論區(qū)留言交流!我們一起進(jìn)步吧~ ??
小貼士
- 探索更多:除了基本的DOM操作,
ref還可以用于更高級(jí)的場(chǎng)景,比如與第三方庫集成、動(dòng)態(tài)組件加載等。 - 持續(xù)學(xué)習(xí):保持對(duì)新技術(shù)的好奇心,不斷學(xué)習(xí)新的知識(shí)和技能,會(huì)讓你在這個(gè)快速發(fā)展的領(lǐng)域中始終領(lǐng)先一步!
到此這篇關(guān)于Vue3中Refs的文章就介紹到這了,更多相關(guān)vue3 $refs解析內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Element?table組件滾動(dòng)條不顯示的踩坑記錄
這篇文章主要介紹了關(guān)于Element?table組件滾動(dòng)條不顯示的踩坑記錄,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
VUE項(xiàng)目運(yùn)行失敗原因及解決辦法圖解(以vscode為例)
記錄一下踩坑,前幾天從同事手上接手了一個(gè)Vue的項(xiàng)目,下面這篇文章主要給大家介紹了關(guān)于VUE項(xiàng)目運(yùn)行失敗原因及解決辦法的相關(guān)資料,本文以vscode為例,需要的朋友可以參考下2023-06-06
關(guān)于json-bigint處理大數(shù)字問題
這篇文章主要介紹了關(guān)于json-bigint處理大數(shù)字問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05
vue3中如何使用ref和reactive定義和修改響應(yīng)式數(shù)據(jù)(最新推薦)
這篇文章主要介紹了vue3中如何使用ref和reactive定義和修改響應(yīng)式數(shù)據(jù),這里就是vue3中setup組合式api中如何定義響應(yīng)式數(shù)據(jù)并且修改賦值全部內(nèi)容,需要的朋友可以參考下2022-12-12
關(guān)于vue3.0中的this.$router.replace({ path: ''/''})刷新無效果問題
這篇文章主要介紹了關(guān)于vue3.0中的this.$router.replace({ path: '/'})刷新無效果問題,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01
element-ui組件table實(shí)現(xiàn)自定義篩選功能的示例代碼
這篇文章主要介紹了element-ui組件table實(shí)現(xiàn)自定義篩選功能的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03
vue以組件或者插件的形式實(shí)現(xiàn)throttle或者debounce
這篇文章主要介紹了vue以組件或者插件的形式實(shí)現(xiàn)throttle或者debounce,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05

