久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue 動(dòng)態(tài)組件用法示例小結(jié)

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

本文實(shí)例講述了vue 動(dòng)態(tài)組件用法。分享給大家供大家參考,具體如下:

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

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

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點(diǎn)擊顯示子組件</button> <component v-bind:is='which_to_show'></component></div><script>// 創(chuàng)建根實(shí)例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 動(dòng)態(tài)組件用法示例小結(jié)

#keep-alive

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

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點(diǎn)擊顯示子組件</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>// 創(chuàng)建根實(shí)例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屬性中只有一個(gè)元素(first組件),

點(diǎn)擊按鈕切換后,vm.$children屬性中有兩個(gè)元素,

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

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

actived鉤子

可以延遲執(zhí)行當(dāng)前的組件。

具體用法來說,activate是和template、data等屬性平級(jí)的一個(gè)屬性,形式是一個(gè)函數(shù),函數(shù)里默認(rèn)有一個(gè)參數(shù),而這個(gè)參數(shù)是一個(gè)函數(shù),執(zhí)行這個(gè)函數(shù)時(shí),才會(huì)切換組件。

<!DOCTYPE html><html><head><meta charset='utf-8'><title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title><script src='https://cdn.bootcss.com/vue/2.2.2/vue.min.js'></script></head><body><div id='app'> <button @click=’toShow’>點(diǎn)擊顯示子組件</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>// 創(chuàng)建根實(shí)例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: { //第一個(gè)子組件template: '<div>這里是子組件1</div>' }, second: { //第二個(gè)子組件template: '<div>這里是子組件2,這里是延遲后的內(nèi)容:{{hello}}</div>',data: function () { return { hello: '' }},activated: function (done) { //執(zhí)行這個(gè)參數(shù)時(shí),才會(huì)切換組件 console.log(’hhh’) var self = this; var startTime = new Date().getTime(); // get the current time //兩秒后執(zhí)行 while (new Date().getTime() < startTime + 2000){ self.hello=’我是延遲后的內(nèi)容’; }} }, third: { //第三個(gè)子組件template: '<div>這里是子組件3</div>' } } });</script></body></html>

vue 動(dòng)態(tài)組件用法示例小結(jié)

當(dāng)切換到第二個(gè)組件的時(shí)候,會(huì)先執(zhí)行activated鉤子,會(huì)在兩秒后顯示組件2.起到了延遲加載的作用。

希望本文所述對(duì)大家vue.js程序設(shè)計(jì)有所幫助。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 金阳县| 青神县| 宜州市| 石泉县| 桐城市| 明溪县| 松潘县| 南皮县| 永修县| 扶沟县| 岢岚县| 兴业县| 本溪| 珲春市| 喀什市| 阿勒泰市| 固始县| 瑞昌市| 吉安市| 太谷县| 长武县| 清原| 盐源县| 湖北省| 法库县| 宜川县| 吉安县| 慈溪市| 景洪市| 永清县| 安仁县| 喀喇沁旗| 北碚区| 叶城县| 云林县| 天台县| 日喀则市| 黎平县| 汉沽区| 河源市| 修水县|