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

Vuejs第十二篇之動態(tài)組件全面解析

 更新時間:2016年09月09日 09:47:59   作者:qq20004604  
組件(Component)是 Vue.js 最強大的功能之一。組件可以擴展 HTML 元素,封裝可重用的代碼。接下來通過本文給大家介紹Vuejs第十二篇之動態(tài)組件,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧

什么是組件?

組件(Component)是 Vue.js 最強大的功能之一。組件可以擴展 HTML 元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能。在有些情況下,組件也可以是原生 HTML 元素的形式,以 is 特性擴展。

本篇資料是小編參考官方文檔的基礎(chǔ)上整理的一篇更加細(xì)致的說明,代碼更多更全,非常適合新手學(xué)習(xí)。

官方文檔:

http://cn.vuejs.org/guide/components.html#u52A8_u6001_u7EC4_u4EF6

動態(tài)組件介紹如下所示:

①簡單來說:

就是幾個組件放在一個掛載點下,然后根據(jù)父組件的某個變量來決定顯示哪個,或者都不顯示。

②動態(tài)切換:

在掛載點使用component標(biāo)簽,然后使用v-bind:is=”組件名”,會自動去找匹配的組件名,如果沒有,則不顯示;

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

如示例代碼:

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<component v-bind:is="which_to_show"></component> 
</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 < 3) { 
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> 

說明:

點擊父組件的按鈕,會自動切換顯示某一個子組件(根據(jù)which_to_show這個變量的值來決定)。

③keep-alive

簡單來說,被切換掉(非當(dāng)前顯示)的組件,是直接被移除了。
在父組件中查看this.$children屬性,可以發(fā)現(xiàn),當(dāng)子組件存在時,該屬性的length為1,而子組件不存在時,該屬性的length是0(無法獲取到子組件);

假如需要子組件在切換后,依然需要他保留在內(nèi)存中,避免下次出現(xiàn)的時候重新渲染。那么就應(yīng)該在component標(biāo)簽中添加keep-alive屬性。

如代碼:

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<component v-bind:is="which_to_show" keep-alive></component> 
</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 < 3) { 
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> 

說明:

初始情況下,vm.$children屬性中只有一個元素(first組件),點擊按鈕切換后,vm.$children屬性中有兩個元素,再次切換后,則有三個元素(三個子組件都保留在內(nèi)存中)。

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

④activate鉤子

簡單來說,他是延遲加載。

例如,在發(fā)起ajax請求時,會需要等待一些時間,假如我們需要在ajax請求完成后,再進(jìn)行加載,那么就需要用到activate鉤子了。

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

為了證明他的延遲加載性,在服務(wù)器端我設(shè)置當(dāng)發(fā)起某個ajax請求時,會延遲2秒才返回內(nèi)容,因此,第一次切換組件2時,需要等待2秒才會成功切換:

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<component v-bind:is="which_to_show"></component> 
</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 < 3) { 
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,這里是ajax后的內(nèi)容:{{hello}}</div>", 
data: function () { 
return { 
hello: "" 
} 
}, 
activate: function (done) { //執(zhí)行這個參數(shù)時,才會切換組件 
var self = this; 
$.get("/test", function (data) { //這個ajax我手動在服務(wù)器端設(shè)置延遲為2000ms,因此需要等待2秒后才會切換 
self.hello = data; 
done(); //ajax執(zhí)行成功,切換組件 
}) 
} 
}, 
third: { //第三個子組件 
template: "<div>這里是子組件3</div>" 
} 
} 
}); 
</script> 

代碼效果:

【1】第一次切換到組件2時,需要等待2秒后才能顯示(因為發(fā)起ajax);

【2】在有keep-alive的情況下,第二次或之后切換到組件2時,無需等待;但ajax內(nèi)容,需要在第一次發(fā)起ajax兩秒后才會顯示;

【3】在無keep-alive的情況下(切換掉后沒有保存在內(nèi)存中),第二次切換到組件2時,依然需要等待。

【4】等待時,不影響再次切換(即等待組件2的時候,再次點擊切換,可以直接切換到組件3);

說明:

【1】只有在第一次渲染組件時,才會執(zhí)行activate,且該函數(shù)只會執(zhí)行一次(在第一次組件出現(xiàn)的時候延遲組件出現(xiàn))

【2】沒有keep-alive時,每次切換組件出現(xiàn)都是重新渲染(因為之前隱藏時執(zhí)行了destroy過程),因此會執(zhí)行activate方法。

⑤transition-mode過渡模式

簡單來說,動態(tài)組件切換時,讓其出現(xiàn)動畫效果。(還記不記得在過渡那一節(jié)的說明,過渡適用于動態(tài)組件)
默認(rèn)是進(jìn)入和退出一起完成;(可能造成進(jìn)入的內(nèi)容出現(xiàn)在退出內(nèi)容的下方,這個下方指y軸方面偏下的,等退出完畢后,進(jìn)入的才會出現(xiàn)在正確的位置);

transition-mode=”out-in”時,動畫是先出后進(jìn);
transition-mode=”in-out”時,動畫是先進(jìn)后出(同默認(rèn)情況容易出現(xiàn)的問題);

示例代碼:(使用自定義過渡名和animate.css文件)

<div id="app"> 
<button @click="toshow">點擊讓子組件顯示</button> 
<component v-bind:is="which_to_show" class="animated" transition="bounce" transition-mode="out-in"></component> 
</div> 
<script> 
Vue.transition("bounce", { 
enterClass: 'bounceInLeft', 
leaveClass: 'bounceOutRight' 
}) 
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 < 3) { 
this.which_to_show = arr[index + 1]; 
} else { 
this.which_to_show = arr[0]; 
} 
} 
}, 
components: { 
first: { //第一個子組件 
template: "<div>這里是子組件1</div>" 
}, 
second: { //第二個子組件 
template: "<div>這里是子組件2,這里是ajax后的內(nèi)容:{{hello}}</div>", 
data: function () { 
return { 
hello: "" 
} 
} 
}, 
third: { //第三個子組件 
template: "<div>這里是子組件3</div>" 
} 
} 
}); 
</script> 

以上所述是小編給大家介紹的Vuejs第十二篇之動態(tài)組件,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue實現(xiàn)簡單的登錄彈出框

    vue實現(xiàn)簡單的登錄彈出框

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)簡單的登錄彈出框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-10-10
  • Vue中div contenteditable 的光標(biāo)定位方法

    Vue中div contenteditable 的光標(biāo)定位方法

    今天小編就為大家分享一篇Vue中div contenteditable 的光標(biāo)定位方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-08-08
  • Vue監(jiān)聽使用方法和過濾器實現(xiàn)

    Vue監(jiān)聽使用方法和過濾器實現(xiàn)

    這篇文章主要介紹了Vue監(jiān)聽使用方法和過濾器實現(xiàn),過濾器為頁面中數(shù)據(jù)進(jìn)行強化,具有局部過濾器和全局過濾器
    2022-06-06
  • 詳解VUE項目中安裝和使用vant組件

    詳解VUE項目中安裝和使用vant組件

    這篇文章主要介紹了VUE安裝和使用vant組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue自定義封裝按鈕組件

    vue自定義封裝按鈕組件

    這篇文章主要為大家詳細(xì)介紹了vue自定義封裝按鈕組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • 安裝nvm?node版本管理器的操作方法(vue2.x遷移vue3.x)

    安裝nvm?node版本管理器的操作方法(vue2.x遷移vue3.x)

    這篇文章主要介紹了安裝nvm?node版本管理器(vue2.x遷移vue3.x)的操作方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-01-01
  • mpvue全局引入sass文件的方法步驟

    mpvue全局引入sass文件的方法步驟

    這篇文章主要介紹了mpvue全局引入sass文件的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vue 表單驗證按鈕事件交由父組件觸發(fā)的方法

    vue 表單驗證按鈕事件交由父組件觸發(fā)的方法

    這篇文章主要介紹了vue 表單驗證按鈕事件交由父組件觸發(fā)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • vue使用SVG實現(xiàn)圓形進(jìn)度條音樂播放

    vue使用SVG實現(xiàn)圓形進(jìn)度條音樂播放

    這篇文章主要為大家詳細(xì)介紹了vue使用SVG實現(xiàn)圓形進(jìn)度條音樂播放,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vite+vue3使用@路徑報錯處理

    vite+vue3使用@路徑報錯處理

    本文主要介紹了vite+vue3使用@路徑報錯處理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-11-11

最新評論