欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue中ref標(biāo)簽屬性和$ref的關(guān)系解讀

 更新時(shí)間:2023年07月18日 17:02:26   作者:考拉菜鳥(niǎo)  
這篇文章主要介紹了vue中ref標(biāo)簽屬性和$ref的關(guān)系,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

vue ref標(biāo)簽屬性和$ref關(guān)系

javascript原生語(yǔ)法和jquery都是屬于操作DOM節(jié)點(diǎn)元素,去實(shí)現(xiàn)功能的.

Vue給我們提供了一個(gè)專(zhuān)門(mén)用來(lái)獲取DOM節(jié)點(diǎn)的方法,使用元素的ref屬性,使用起來(lái)非常方便。

(這只是用于偶爾vue需要操作節(jié)點(diǎn)時(shí)候才使用)

vue的ref屬性

ref 被用來(lái)給元素或子組件注冊(cè)引用信息。

引用信息將會(huì)注冊(cè)在父組件的 $refs 對(duì)象上。

如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子組件上,引用就指向組件實(shí)例:

<!-- `vm.$refs.p` will be the DOM node -->
<p ref="p">hello</p>
<!-- `vm.$refs.child` will be the child component instance -->
<child-component ref="child"></child-component>

當(dāng) v-for 用于元素或組件的時(shí)候,引用信息將是包含 DOM 節(jié)點(diǎn)或組件實(shí)例的數(shù)組。

關(guān)于 ref 注冊(cè)時(shí)間的重要說(shuō)明:因?yàn)?ref 本身是作為渲染結(jié)果被創(chuàng)建的,在初始渲染的時(shí)候你不能訪問(wèn)它們 - 它們還不存在!$refs 也不是響應(yīng)式的,因此你不應(yīng)該試圖用它在模板中做數(shù)據(jù)綁定。

vm.$refs

一個(gè)對(duì)象,持有 注冊(cè)過(guò) ref 特性 的所有 DOM 元素和組件實(shí)例。

以上是官方文檔里面的內(nèi)容,總結(jié)為下面的:

  • 給要獲取的元素節(jié)點(diǎn)添加ref屬性,使用有意義的駝峰命名
  • 通過(guò)vue實(shí)例.$refs.屬性名即可獲取標(biāo)記的元素,我們?cè)趍ounted鉤子函數(shù)中調(diào)用可以直接使用this指向當(dāng)前vue實(shí)例,這個(gè)才是vue推薦的元素獲取方式
  • 如果ref重名后面的會(huì)把前面的覆蓋
  • 元素使用v-for,返回dom節(jié)點(diǎn)數(shù)組

下面舉例驗(yàn)證

<div id="app">
        <div>
            <h2 ref="name1">這是name1節(jié)點(diǎn)元素</h2>
            <p ref="name2">這是name2節(jié)點(diǎn)元素</p>
        </div>
 </div>
 mounted() {
                console.log(this);   //vue實(shí)例對(duì)象
                console.log(this.$refs.name1);   //上面的h2標(biāo)簽元素
                console.log(this.$refs.name1.textContent);  //標(biāo)簽內(nèi)容
                console.log(this.$refs.name2);  //上面的p標(biāo)簽元素                
            },

在這里插入圖片描述

如果ref值重復(fù)時(shí),會(huì)打印出哪個(gè)DOM節(jié)點(diǎn)? 根據(jù)上面的知識(shí)點(diǎn),我們知道,后面的會(huì)覆蓋前面的

下面驗(yàn)證一下:

     <div id="app">       
        <h2 ref="name1">這是name1節(jié)點(diǎn)元素</h2>
        <p ref="name2">這是name2節(jié)點(diǎn)元素</p>
   		 <span ref="name1">這是ref的name1值重復(fù)的節(jié)點(diǎn)元素</span><br>
   		 <i ref="name2">這是ref的name2值重復(fù)的節(jié)點(diǎn)元素</i><br>
	  </div>	  

一樣在代碼中執(zhí)行以下命令

mounted() {
                console.log(this);   //vue實(shí)例對(duì)象
                console.log(this.$refs.name1);   //上面的h2標(biāo)簽元素
                console.log(this.$refs.name1.textContent);  //標(biāo)簽內(nèi)容
                console.log(this.$refs.name2);  //上面的p標(biāo)簽元素                
            },

在這里插入圖片描述

打印結(jié)果是span和i標(biāo)簽元素,覆蓋了前面的h2和p標(biāo)簽

如果把ref值設(shè)置ul標(biāo)簽

<ul  ref="veg">
   <li>水果1</li>
   <li>水果2</li>
   <li>水果3</li>
</ul>

執(zhí)行

console.log(this.$refs.veg);

在這里插入圖片描述

直接打印出整個(gè)DOM對(duì)象

當(dāng)v-for用于元素和組件的時(shí)候,引用信息將是包含 DOM 節(jié)點(diǎn)或組件實(shí)例的數(shù)組。

 <div id="app">
        <ul>
            <li ref="fruits" v-for="(item,index) in arr" :key="index">水果{{item}}</li>
        </ul>
   </div>
 const app = new Vue({
            el: '#app',
            mounted() {               
                console.log(this.$refs.fruits); //打印的是li標(biāo)簽數(shù)組
                console.log(this.$refs.fruits[1].textContent);
            },
            data: {
                arr: [1, 2, 3, 4, 5],
            },
        });

運(yùn)行

console.log(this.$refs.fruits);

以后得到的數(shù)組

在這里插入圖片描述

新手對(duì)vue中特殊的標(biāo)簽屬性ref和key的理解

ref屬性

  • 定義:用來(lái)給元素或子組件注冊(cè)引用信息
  • 理解:類(lèi)似id(原生js中id的替代者),給元素或者組件打標(biāo)識(shí)

作用

1、應(yīng)用在html標(biāo)簽上,是用來(lái)獲取真實(shí)的DOM元素(相當(dāng)于原生的document.getElementById("xxx"))

2、應(yīng)用在組件標(biāo)簽上,得到的是組件的實(shí)例對(duì)象

使用方式

第一步:打標(biāo)識(shí)

<h1 ref="xxx">...</h1>
<School ref="xxx"></School>

第二步:獲取

this.$refs.xxx

ref屬性與原生的id屬性的區(qū)別

1、添加在html標(biāo)簽上

兩者結(jié)果相同,都是得到真實(shí)的DOM元素

2、添加到組件上

  • ref屬性獲取的是組件實(shí)例對(duì)象
  • id屬性相當(dāng)于給組件最外層容器添加了id屬性,得到的是最外層包裹著的所有真實(shí)DOM元素

key屬性

理解:給虛擬DOM對(duì)象添加標(biāo)識(shí),相當(dāng)于給每個(gè)元素添加一個(gè)獨(dú)一無(wú)二的id身份

作用:當(dāng)數(shù)據(jù)發(fā)生變化時(shí),Vue會(huì)根據(jù)新數(shù)據(jù)生成新的虛擬DOM,隨后Vue進(jìn)行新舊虛擬DOM的差異對(duì)比,比較規(guī)則如下:

對(duì)比規(guī)則

1、舊虛擬DOM中找到與新虛擬DOM相同的key

  • ① 若虛擬DOM中的內(nèi)容沒(méi)有變化,那么直接使用之前的真實(shí)DOM
  • ② 若虛擬DOM中的內(nèi)容變化了,則生成新的真實(shí)DOM,隨后替換掉頁(yè)面之前的DOM

2、新虛擬DOM中未找到與舊虛擬DOM相同的key

創(chuàng)建真實(shí)的DOM,隨后渲染到頁(yè)面

用index作為key可能引發(fā)的問(wèn)題

1、若對(duì)數(shù)據(jù)進(jìn)行:逆序添加和刪除等破壞數(shù)據(jù)順序的操作

會(huì)產(chǎn)生沒(méi)有必須的真實(shí)DOM更新,頁(yè)面效果沒(méi)問(wèn)題,但效率低

2、若結(jié)構(gòu)中包含輸入類(lèi)的DOM

會(huì)產(chǎn)生錯(cuò)誤的DOM更新,頁(yè)面出現(xiàn)問(wèn)題

開(kāi)發(fā)中如何選擇key?

  • ① 如果數(shù)據(jù)有唯一標(biāo)識(shí),比如id,身份證號(hào),學(xué)號(hào)等,可以直接使用數(shù)據(jù)的唯一標(biāo)識(shí)
  • ② 如果不存在逆序等破壞順序的操作,僅用于渲染展示,那么使用index作為key值沒(méi)有問(wèn)題

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue利用draggable實(shí)現(xiàn)多選拖拽效果

    Vue利用draggable實(shí)現(xiàn)多選拖拽效果

    這篇文章主要為大家詳細(xì)介紹了如何利用vue中的draggable插件實(shí)現(xiàn)多選拖拽效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • el-table-column疊加el-popover使用示例小結(jié)

    el-table-column疊加el-popover使用示例小結(jié)

    el-table-column有一列展示多個(gè)tag信息,實(shí)現(xiàn)點(diǎn)擊tag展示tag信息以及tag對(duì)應(yīng)的詳細(xì)信息,本文通過(guò)示例代碼介紹el-table-column疊加el-popover使用示例小結(jié),感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • vue.js select下拉框綁定和取值方法

    vue.js select下拉框綁定和取值方法

    下面小編就為大家分享一篇vue.js select下拉框綁定和取值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • Vue3如何清空Reactive定義的數(shù)組

    Vue3如何清空Reactive定義的數(shù)組

    這篇文章主要介紹了Vue3如何清空Reactive定義的數(shù)組問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue刷新后瞬間閃爍,無(wú)法解析的問(wèn)題

    vue刷新后瞬間閃爍,無(wú)法解析的問(wèn)題

    這篇文章主要介紹了vue刷新后瞬間閃爍,無(wú)法解析的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue elementui form表單驗(yàn)證的實(shí)現(xiàn)

    vue elementui form表單驗(yàn)證的實(shí)現(xiàn)

    這篇文章主要介紹了vue elementui form表單驗(yàn)證的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-11-11
  • 詳解Vue如何進(jìn)行表單聯(lián)動(dòng)與級(jí)聯(lián)選擇

    詳解Vue如何進(jìn)行表單聯(lián)動(dòng)與級(jí)聯(lián)選擇

    表單聯(lián)動(dòng)和級(jí)聯(lián)選擇是Vue.js中常見(jiàn)的功能,在下面的文章中,我們將討論如何在Vue.js中實(shí)現(xiàn)表單聯(lián)動(dòng)和級(jí)聯(lián)選擇,感興趣的小伙伴可以了解一下
    2023-06-06
  • vue組件暴露和.js文件暴露接口操作

    vue組件暴露和.js文件暴露接口操作

    這篇文章主要介紹了vue組件暴露和.js文件暴露接口操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-08-08
  • vue實(shí)現(xiàn)輸入框自動(dòng)跳轉(zhuǎn)功能

    vue實(shí)現(xiàn)輸入框自動(dòng)跳轉(zhuǎn)功能

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)輸入框自動(dòng)跳轉(zhuǎn)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 在Vue3中實(shí)現(xiàn)子組件向父組件傳遞數(shù)據(jù)的代碼示例

    在Vue3中實(shí)現(xiàn)子組件向父組件傳遞數(shù)據(jù)的代碼示例

    Vue3作為目前最熱門(mén)的前端框架之一,以其輕量化、易用性及性能優(yōu)勢(shì)吸引了大量開(kāi)發(fā)者,在開(kāi)發(fā)過(guò)程中,不可避免地需要在組件之間傳遞數(shù)據(jù),本文將詳細(xì)講解在Vue3中如何實(shí)現(xiàn)子組件向父組件傳遞數(shù)據(jù),并通過(guò)具體示例代碼使概念更加清晰
    2024-07-07

最新評(píng)論