成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Vue 實例中使用$refs的注意事項

瀏覽:4日期:2022-10-07 14:43:26

在開發過程中,經常會通過實例的vm.$refs(this.$refs)取得通過ref注冊過的組件,并進行相應操作,但存在取不到元素的情況,其根本原因是因為$refs只能取得mounted(渲染)之后的元素。

Vue 實例中使用$refs的注意事項

例如,在這種情況中,若flag從真值切換到假值取不到節點是正常的,因為v-if如果為假值,那么該節點不會被渲染。

但如果從假值切換到真值時,也可能取不到節點,這是因為渲染需要時間,通常可以使用$nextTick()解決。

...<el-table v-if='flag' ref='table'> <el-table-column prop='prop1'></el-table-column> <el-table-column prop='prop2'></el-table-column></el-table>... export default { methods: { this.$refs.table.XXX() }}

但存在一個極特殊的情況,第一次頁面渲染的時候,$refs也取不到值。這個時候就要考慮v-show進行組件元素的隱藏與展示。

因為v-show是通過css的display:none進行隱藏控制,所以一開始就會渲染,肯定能夠取到元素

補充:Vue.js中ref ($refs)用法舉例總結及應注意的坑

一、根據官方文檔總結的用法:

看Vue.js文檔中的ref部分,自己總結了下ref的使用方法以便后面查閱。

1、ref使用在外面的組件上

HTML 部分

<div v-on:click='consoleRef'> <component-father ref='outsideComponentRef'> </component-father> <p>ref在外面的組件上</p></div>

js部分

var refoutsidecomponentTem={ template:'<div class=’childComp’><h5>我是子組件</h5></div>' }; var refoutsidecomponent=new Vue({ el:'#ref-outside-component', components:{ 'component-father':refoutsidecomponentTem }, methods:{ consoleRef:function () {console.log(this); // #ref-outside-component vue實例console.log(this.$refs.outsideComponentRef); // div.childComp vue實例 } } });

2、ref使用在外面的元素上

HTML部分

<!--ref在外面的元素上--><div v-on:click='consoleRef' > <component-father> </component-father> <p ref='outsideDomRef'>ref在外面的元素上</p></div>

JS部分

var refoutsidedomTem={ template:'<div class=’childComp’><h5>我是子組件</h5></div>' }; var refoutsidedom=new Vue({ el:'#ref-outside-dom', components:{ 'component-father':refoutsidedomTem }, methods:{ consoleRef:function () {console.log(this); // #ref-outside-dom vue實例console.log(this.$refs.outsideDomRef); // <p> ref在外面的元素上</p> } } });

3、ref使用在里面的元素上---局部注冊組件

HTML部分

<!--ref在里面的元素上--><div id='ref-inside-dom'> <component-father> </component-father> <p>ref在里面的元素上</p></div>

JS部分

var refinsidedomTem={ template:'<div class=’childComp’ v-on:click=’consoleRef’>' + '<h5 ref=’insideDomRef’>我是子組件</h5>' + '</div>', methods:{ consoleRef:function () {console.log(this); // div.childComp vue實例 console.log(this.$refs.insideDomRef); // <h5 >我是子組件</h5> } } }; var refinsidedom=new Vue({ el:'#ref-inside-dom', components:{ 'component-father':refinsidedomTem } });

4、ref使用在里面的元素上---全局注冊組件

HTML部分

<!--ref在里面的元素上--全局注冊--><div id='ref-inside-dom-all'> <ref-inside-dom-quanjv></ref-inside-dom-quanjv></div>

JS部分

Vue.component('ref-inside-dom-quanjv',{ template:'<div class=’insideFather’> ' + '<input type=’text’ ref=’insideDomRefAll’ v-on:input=’showinsideDomRef’>' + ' <p>ref在里面的元素上--全局注冊 </p> ' + '</div>', methods:{ showinsideDomRef:function () {console.log(this); //這里的this其實還是div.insideFatherconsole.log(this.$refs.insideDomRefAll); // <input type='text'> } } }); var refinsidedomall=new Vue({ el:'#ref-inside-dom-all' });二、應注意的坑

1、如果通過v-for 遍歷想加不同的ref時記得加 :號,即 :ref =某變量 ;

這點和其他屬性一樣,如果是固定值就不需要加 :號,如果是變量記得加 :號

Vue 實例中使用$refs的注意事項

2、通過 :ref =某變量 添加ref(即加了:號) ,如果想獲取該ref時需要加 [0],如this.$refs[refsArrayItem] [0];如果不是:ref =某變量的方式而是 ref =某字符串時則不需要加,如this.$refs[refsArrayItem]

Vue 實例中使用$refs的注意事項

加和不加[0]的區別--未展開

Vue 實例中使用$refs的注意事項

加和不加[0]的區別--展開了

3、想在element ui 對話框打開后取dom時,應該使用$nextTick,而不是直接使用this.$refs. imgLocal2:

console.log(’this.$refs.imgLocal2外面’, this.$refs.imgLocal2); setTimeout(() => { console.log(’this.$refs.imgLocal2 setTimeout’, this.$refs.imgLocal2); }, 500); // 不推薦 this.$nextTick(() => { console.log(’this.$refs.imgLocal2 $nextTick’, this.$refs.imgLocal2); });

Vue 實例中使用$refs的注意事項

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持好吧啦網。如有錯誤或未考慮完全的地方,望不吝賜教。

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲尤物视频在线| 丝袜亚洲精品中文字幕一区| 一区二区三区四区在线播放 | 26uuu久久天堂性欧美| 亚洲成a人v欧美综合天堂下载 | 另类激情亚洲| 成人三级伦理片| 在线免费观看视频一区| 亚洲国产日日夜夜| 99av国产精品欲麻豆| 欧美日韩亚洲综合一区二区三区| 同产精品九九九| 亚洲一区二区三区涩| 国内视频精品| 国产一区 二区 三区一级| 欧美日韩性生活| 亚洲免费电影在线| 99精品国产热久久91蜜凸| 欧美一级高清大全免费观看| 成人在线视频首页| 欧美日本韩国一区二区三区| 国产精品嫩草影院com| 日韩一级二级三级| 在线观看一区不卡| 99免费精品视频| 日本在线不卡视频一二三区| 国产精品污污网站在线观看| 色天使色偷偷av一区二区| 国产一区二区三区不卡在线观看 | 亚洲一区日韩| 亚洲三级久久久| 99视频一区| 国产精品国产三级国产aⅴ原创| 国产综合婷婷| 亚洲精品国产无天堂网2021 | 欧美一级一区二区| 国产一区久久久| 日韩一区二区三区视频| 国产mv日韩mv欧美| 精品盗摄一区二区三区| 欧美另类亚洲| 一区二区三区四区精品在线视频| 裸体素人女欧美日韩| 免费在线观看成人| 777午夜精品视频在线播放| 国产福利精品导航| 亚洲精品一区二区三区蜜桃下载| 欧美成熟视频| 亚洲女同女同女同女同女同69| 99热这里只有精品8| 午夜精品久久久久久久久久久| 色婷婷久久综合| 国产在线精品一区二区| 欧美一卡二卡在线| 色综合中文字幕| 中文字幕中文在线不卡住| 一区二区三区四区五区视频| 婷婷综合五月天| 欧美一区二区视频在线观看2022| 丁香六月久久综合狠狠色| 久久在线观看免费| 欧美激情1区2区| 亚洲欧美国产高清| 色天天综合久久久久综合片| 国产成人久久精品77777最新版本| 久久精品视频在线看| 在线综合亚洲| 美国毛片一区二区| 日韩欧美国产一区二区三区 | 欧美在线免费视屏| 大桥未久av一区二区三区中文| 国产欧美日本一区二区三区| 一区二区三区精品视频在线观看| 香蕉久久一区二区不卡无毒影院 | 久久久久国产免费免费| 99视频精品| 久久精品久久综合| 久久先锋影音av| 日韩视频中文| 久99久精品视频免费观看| 2024国产精品| 亚洲乱码视频| 久久av中文字幕片| 国产日产欧美一区二区三区| 性欧美长视频| 成人午夜电影小说| 亚洲人成精品久久久久| 在线看一区二区| 成人影视亚洲图片在线| 亚洲老司机在线| 91精品视频网| 在线播放不卡| 激情六月婷婷综合| 国产精品美日韩| 在线视频一区二区三| 91小视频免费观看| 亚洲一区二区精品视频| 91精品国产免费| 亚洲精选一区| 国产精品一二三在| 一区二区三区精品| 日韩欧美中文一区二区| 一本久道久久久| 国产一区在线看| 中文字幕综合网| 欧美精品 国产精品| 9久re热视频在线精品| 国产精品一区二区在线观看网站 | 美国十次综合导航| 亚洲欧美另类图片小说| 7777精品伊人久久久大香线蕉的| 黑人一区二区三区四区五区| 九色porny丨国产精品| 国产精品你懂的| 欧美精品在线视频| 99综合精品| 99久久777色| 日韩高清在线不卡| 国产精品久久久久久久久晋中 | 久久xxxx| 欧美午夜精品久久久久免费视| 精品在线视频一区| 亚洲三级小视频| 亚洲精品在线观看网站| 色综合久久久网| 国产精品hd| 国产电影精品久久禁18| 亚洲成a人v欧美综合天堂| 国产亚洲精久久久久久| 欧美日本免费一区二区三区| 在线视频免费在线观看一区二区| 成人短视频下载| 免费久久99精品国产| 亚洲视频免费观看| 久久久噜噜噜久久中文字幕色伊伊| 欧美性色黄大片手机版| 国产日韩综合| 国产精品av久久久久久麻豆网| 国产精品99久久久久久久女警| 亚洲最快最全在线视频| 国产亚洲1区2区3区| 91麻豆精品国产91久久久资源速度 | 国产精品激情电影| 成人性生交大片免费看视频在线| 热久久一区二区| 亚洲乱码国产乱码精品精小说| 精品不卡在线视频| 91精品一区二区三区在线观看| 色婷婷狠狠综合| 国产一区白浆| 韩日精品视频| 色综合色狠狠天天综合色| 国产一区二区在线免费观看| 亚洲电影欧美电影有声小说| 中文字幕亚洲一区二区av在线 | 日本久久电影网| 亚欧美中日韩视频| 国产精品大片| 99天天综合性| 福利电影一区二区| 国产一区福利在线| 久久国产乱子精品免费女| 亚洲国产精品久久人人爱| 最新不卡av在线| 国产色产综合产在线视频| 日韩视频免费直播| 7878成人国产在线观看| 精品视频在线看| 色94色欧美sute亚洲线路一ni| 国产美女诱惑一区二区| 99精品视频免费观看| 亚洲精品女人| 国产精品av一区二区| 欧美大片一区| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 99视频+国产日韩欧美| 亚洲国产日韩综合一区| 红桃视频国产精品| 欧美国内亚洲| 99久久久国产精品免费蜜臀| 成av人片一区二区| 成人av免费在线观看| 丁香婷婷深情五月亚洲| 国产suv精品一区二区6| 国产成人午夜精品影院观看视频 | 欧美成va人片在线观看| 日韩亚洲欧美一区二区三区| 91精品国产品国语在线不卡| 欧美另类一区二区三区| 56国语精品自产拍在线观看| 欧美精品日韩精品| 欧美二区三区91| 欧美一区二区三区人| 欧美一区二区三区日韩| 日韩精品自拍偷拍| 久久婷婷久久一区二区三区| 亚洲精品一区二区三区精华液| 久久综合色综合88| 国产欧美一区二区在线观看| 欧美韩国日本综合|