Vue3中的Refs全解析(附實(shí)戰(zhàn)案例)
前言
今天給大家?guī)硪粋€(gè)超級實(shí)用的Vue3技巧:如何使用ref實(shí)現(xiàn)DOM元素和組件實(shí)例的引用!如果你在開發(fā)過程中需要直接操作DOM或訪問子組件的方法,那么ref
絕對是你的最佳選擇!話不多說,直接開整~
什么是Ref?
在Vue3中,ref
是一個(gè)非常強(qiáng)大的功能,它允許你創(chuàng)建對DOM元素或子組件實(shí)例的引用。通過這種方式,你可以直接訪問并操作這些元素或組件,而不需要依賴于事件處理或其他間接方法。
核心作用:簡化了直接操作DOM或調(diào)用子組件方法的過程,使得代碼更加直觀易懂!
Refs的核心原理
當(dāng)你在一個(gè)模板中使用ref
屬性時(shí),Vue會(huì)將對應(yīng)的DOM元素或組件實(shí)例存儲(chǔ)到一個(gè)響應(yīng)式的引用對象中。這個(gè)對象可以通過this.$refs
(在選項(xiàng)API中)或者直接作為變量(在組合API中)來訪問。
- 定義Ref:為DOM元素或組件添加
ref
屬性。 - 獲取Ref:通過
this.$refs
或ref
變量獲取引用。 - 操作Ref:利用獲取到的引用進(jìn)行各種操作,如修改樣式、觸發(fā)事件等。
實(shí)戰(zhàn)案例:基礎(chǔ)用法
假設(shè)我們有一個(gè)場景:想要點(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)用場景
動(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)證場景下,可以直接通過
ref
訪問表單元素,進(jìn)行即時(shí)驗(yàn)證或提交前的檢查。
- 在表單驗(yàn)證場景下,可以直接通過
動(dòng)畫控制
- 對于復(fù)雜的動(dòng)畫效果,有時(shí)需要直接操作DOM元素,這時(shí)
ref
就派上用場了。
- 對于復(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)用場景,了解了如何在實(shí)際項(xiàng)目中利用該特性簡化DOM操作和組件間通信。無論是簡單的屬性修改還是復(fù)雜的交互邏輯,ref
都能讓你的工作更加高效!
希望這篇教程能幫到大家!如果你覺得有用的話,記得點(diǎn)贊收藏并關(guān)注我哦~ ??
如果有任何問題或想法,歡迎在評論區(qū)留言交流!我們一起進(jìn)步吧~ ??
小貼士
- 探索更多:除了基本的DOM操作,
ref
還可以用于更高級的場景,比如與第三方庫集成、動(dòng)態(tài)組件加載等。 - 持續(xù)學(xué)習(xí):保持對新技術(shù)的好奇心,不斷學(xué)習(xí)新的知識和技能,會(huì)讓你在這個(gè)快速發(fā)展的領(lǐng)域中始終領(lǐng)先一步!
到此這篇關(guān)于Vue3中Refs的文章就介紹到這了,更多相關(guān)vue3 $refs解析內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于Element?table組件滾動(dòng)條不顯示的踩坑記錄
這篇文章主要介紹了關(guān)于Element?table組件滾動(dòng)條不顯示的踩坑記錄,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08VUE項(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à)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05vue3中如何使用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ì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-01-01element-ui組件table實(shí)現(xiàn)自定義篩選功能的示例代碼
這篇文章主要介紹了element-ui組件table實(shí)現(xiàn)自定義篩選功能的示例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03vue以組件或者插件的形式實(shí)現(xiàn)throttle或者debounce
這篇文章主要介紹了vue以組件或者插件的形式實(shí)現(xiàn)throttle或者debounce,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05