在 vue 中,實現(xiàn) Tab 切換主要有三種方式:使用動態(tài)組件,使用 vue-router 路由,使用第三方插件。
因為這次完成的功能只是簡單切換組件,再則覺得使用路由切換需要改變地址略微麻煩,所以使用的是動態(tài)組件實現(xiàn),如果是在大型應(yīng)用上,可能使用 vue-router 會方便一些。
先看下最終實現(xiàn)的效果,結(jié)構(gòu)比較簡單,頂部的三個 Tab 標(biāo)簽用于切換,內(nèi)容區(qū)域分別為三個子組件。
效果預(yù)覽
關(guān)鍵代碼及分析如下:
<template>// 每一個 tab 綁定了一個點擊事件,傳入的參數(shù)對應(yīng)著 tab 下的組件名<div class="tabs"> <div class="tab" @click="toggleTab('prince')"><a>小王子</a></div> <div class="tab" @click="toggleTab('rose')"><a>小玫瑰</a></div> <div class="tab" @click="toggleTab('fox')"><a>小狐貍</a></div></div>// 子組件,顯示不同的 tab// is 特性動態(tài)綁定子組件// keep-alive 將切換出去的組件保留在內(nèi)存中<prince :is="currentTab" keep-alive></prince></template><script>// 引入子組件import prince from './components/prince';import rose from './components/rose';import fox from './components/fox';export default { name: 'app', data () { return { currentTab: 'prince' // currentTab 用于標(biāo)識當(dāng)前觸發(fā)的子組件 }; }, components: { // 聲明子組件 prince, rose, fox }, methods: { toggleTab: function(tab) { this.currentTab = tab; // tab 為當(dāng)前觸發(fā)標(biāo)簽頁的組件名 } }}</script>
使用動態(tài)組件實現(xiàn) Tab 標(biāo)簽頁切換的基本過程可以概括為:
is 特性一般用于原生 HTML 元素擴(kuò)展
舉個栗子,一般在 ul 標(biāo)簽中只能嵌套 li 標(biāo)簽,但是我們現(xiàn)在想在 ul 標(biāo)簽內(nèi)使用自定義組件 v-li。
<ul> <v-li></v-li></ul>
而這樣寫肯定是不行的,這就需要用到 is 特性了。
<ul> <li is="v-li"></li></ul>
這也就是為什么利用 is 特性可以實現(xiàn)動態(tài)切換組件的效果。
keep-alive 指令可以將切換出去的組件保留在內(nèi)存中,可以保留它的狀態(tài)或避免重新渲染。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。
新聞熱點
疑難解答