亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

vue 動態組件用法示例小結

瀏覽:87日期:2023-02-02 17:01:57

本文實例講述了vue 動態組件用法。分享給大家供大家參考,具體如下:

通過使用保留的 <component> 元素,動態地綁定到它的 is 特性,我們讓多個組件可以使用同一個掛載點,并動態切換。根據 v-bind:is='組件名' 中的組件名去自動匹配組件,如果匹配不到則不顯示。

改變掛載的組件,只需要修改is指令的值即可。

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測試實例 - 動態組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點擊顯示子組件</button> <component v-bind:is='which_to_show'></component></div><script>// 創建根實例new Vue({ el: ’#app’, data:{ which_to_show:’first’ }, methods:{ toShow:function(){ var arr = ['first','second','third']; var index = arr.indexOf(this.which_to_show); if(index<2){ this.which_to_show = arr[index+1]; }else{ this.which_to_show = arr[0]; } } }, components:{ first:{ template:’<div>這是子組件1<div>’ }, second:{ template:’<div>這是子組件2<div>’ }, third:{ template:’<div>這是子組件3<div>’ }, }})</script></body></html>

vue 動態組件用法示例小結

#keep-alive

動態切換掉的組件(非當前顯示的組件)是被移除掉了,如果把切換出去的組件保留在內存中,可以保留它的狀態或避免重新渲染。為此可以添加一個 keep-alive 指令參數:

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測試實例 - 動態組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點擊顯示子組件</button> <!----或者<component v-bind:is='which_to_show' keep-alive></component>也行-----> <keep-alive> <component v-bind:is='which_to_show' ></component> </keep-alive></div><script>// 創建根實例new Vue({ el: ’#app’, data:{ which_to_show:’first’ }, methods:{ toShow:function(){ var arr = ['first','second','third']; var index = arr.indexOf(this.which_to_show); if(index<2){ this.which_to_show = arr[index+1]; }else{ this.which_to_show = arr[0]; } console.log(this.$children); } }, components:{ first:{ template:’<div>這是子組件1<div>’ }, second:{ template:’<div>這是子組件2<div>’ }, third:{ template:’<div>這是子組件3<div>’ }, }})</script></body></html>

說明:

初始情況下,vm.$children屬性中只有一個元素(first組件),

點擊按鈕切換后,vm.$children屬性中有兩個元素,

再次切換后,則有三個元素(三個子組件都保留在內存中)。

之后無論如何切換,將一直保持有三個元素。

actived鉤子

可以延遲執行當前的組件。

具體用法來說,activate是和template、data等屬性平級的一個屬性,形式是一個函數,函數里默認有一個參數,而這個參數是一個函數,執行這個函數時,才會切換組件。

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測試實例 - 動態組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點擊顯示子組件</button> <!----或者<component v-bind:is='which_to_show' keep-alive></component>也行-----> <keep-alive> <component v-bind:is='which_to_show' ></component> </keep-alive></div><script>// 創建根實例var vm = new Vue({ el: ’#app’, data: { which_to_show: 'first' }, methods: { toShow: function () { //切換組件顯示var arr = ['first', 'second', 'third', ''];var index = arr.indexOf(this.which_to_show);if (index < 2) { this.which_to_show = arr[index + 1];} else { this.which_to_show = arr[0];}console.log(this.$children); } }, components: { first: { //第一個子組件template: '<div>這里是子組件1</div>' }, second: { //第二個子組件template: '<div>這里是子組件2,這里是延遲后的內容:{{hello}}</div>',data: function () { return { hello: '' }},activated: function (done) { //執行這個參數時,才會切換組件 console.log(’hhh’) var self = this; var startTime = new Date().getTime(); // get the current time //兩秒后執行 while (new Date().getTime() < startTime + 2000){ self.hello=’我是延遲后的內容’; }} }, third: { //第三個子組件template: '<div>這里是子組件3</div>' } } });</script></body></html>

vue 動態組件用法示例小結

當切換到第二個組件的時候,會先執行activated鉤子,會在兩秒后顯示組件2.起到了延遲加載的作用。

希望本文所述對大家vue.js程序設計有所幫助。

標簽: Vue
相關文章:
主站蜘蛛池模板: 欧美毛片免费看 | 国产一级做a爰片在线 | 中文字幕卡二和卡三的视频 | 欧美日韩国产一区二区三区不卡 | 亚欧一区 | 欧美一区二区三区免费播放 | 国产欧美另类久久精品91 | 日韩人成免费网站大片 | 欧美一二三区视频 | 99久久精品免费看国产免费 | 久久99精品久久久久久久不卡 | 欧美做a一级视频免费观看 欧美做a欧美 | 欧美一级毛片免费观看软件 | 亚洲一区二区三区亚瑟 | 久久国产网站 | 欧美性视频网 | 性生a | 综合精品视频 | 土耳其毛片 | 免费看欧美一级特黄a大片一 | 能看av的网址 | 久久好色| 女人被狂躁的视频免费一一 | 国产人成精品午夜在线观看 | 性色生活片 | 欧美亚洲综合网 | 亚洲国产精品va在线观看麻豆 | 亚洲一区二区三区四区五区 | 日韩在线一区视频 | 国产福利在线视频 | 玖玖草在线观看 | 欧美日韩一区在线观看 | 午夜伦情电午夜伦情影院 | 国产欧美日韩不卡在线播放在线 | 日本二级黄色 | 国语对白清晰好大好白 | 国产精品国产精品国产专区不卡 | 麻豆果冻精品一区二区 | 欧美久操| 国产福利视频 | 黄色体验区|