P粉6008451632023-08-26 13:08:54
我是這樣做的。
<!-- App.vue HTML 部分 --> <li v-for = "(tab, index) in tabs" :key="index" class="nav-link" @click="active_tab = tab" v-bind:class="{ 'active' : tab === active_tab }"> ... </li>
我在一個名為tabs
的陣列中新增了所有我想要新增的選項卡。
<script> export default { name: 'Home', data() { return { active_tab: "Tab1", tabs: ["Tab1", "Tab2", "Tab3"] } } </script>
這將為陣列tabs
中的每個tab
建立一個<li>
元素。
所有的元素都會有nav-link
類,並且使用v-bind
,如果變數active_tab
等於tab
,則會將active
加入到元素的類別清單中。每當使用者點選其中一個標籤時,使用@click
將active_tab
改為使用者點選的tab
。
樣式
.nav-link { background-color: var(--primary-color); /* 正常时元素的外观 */ } .nav-link.active { background-color: var(--hover-color); /* 当元素处于活动状态时 */ }