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

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

vue使用動態組件實現TAB切換效果完整實例

瀏覽:210日期:2022-06-09 17:41:46
目錄
  • 一、方法1:使用Vant組件庫的tab組件
  • 二、 方法2:手動創建tab切換效果
  • 三、完整代碼
  • 總結

一、方法1:使用Vant組件庫的tab組件

二、 方法2:手動創建tab切換效果

1.在components文件夾下創建切換的.vue頁面、引入使用

import one from "./components/one";import two from "./components/two";import three from "./components/three";import four from "./components/four";components: {    one,    two,    three,    four,},

2.布局:上面放tab點擊的標簽,下面放組件呈現對應內容

// 然后使用v-for循環出來呈現<template>   <div id="app">      <div>      <!-- 放置tab點擊標簽 --> <div :class="{ highLight: whichIndex == index }" v-for="(item, index) in cardArr" :key="index" @click="whichIndex = index">    {{ item.componentName }}</div>      </div>      <div><!-- 放置動態組件... -->       <!-- keep-alive緩存組件,這樣的話,組件就不會被銷毀,DOM就不會被重新渲染,       瀏覽器也就不會回流和重繪,就可以優化性能。不使用的話頁面加載就會慢一點 -->       <keep-alive> <component :is="componentId"></component>       </keep-alive>      </div>   </div></template>

3.寫好上面的tab點擊標簽,定義數據修改樣式

// 首先我們在data中定義數組cardArr存放點擊tab的數據data() {   return {      whichIndex: 0,      cardArr: [{  componentName: "動態組件一",  componentId: "one",},{  componentName: "動態組件二",  componentId: "two",},{  componentName: "動態組件三",  componentId: "three",},{  componentName: "動態組件四",  componentId: "four",},      ],    };},
// 又因為需要有高亮狀態樣式:默認索引0高亮.highLight {  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);  transform: translate3d(0, -1px, 0);}

三、完整代碼

<template>  <div id="app">    <div>      <div       :class="{ highLight: whichIndex == index }"v-for="(item, index) in cardArr":key="index"@click="  whichIndex = index;  componentId = item.componentId;"      >{{ item.componentName }}      </div>    </div>    <div>      <keep-alive><component :is="componentId"></component>      </keep-alive>    </div>  </div></template><script>import one from "./components/one";import two from "./components/two";import three from "./components/three";import four from "./components/four";export default {  components: {    one,    two,    three,    four,  },  data() {    return {      whichIndex: 0,      componentId: "one",      cardArr: [{  componentName: "動態組件一",  componentId: "one",},{  componentName: "動態組件二",  componentId: "two",},{  componentName: "動態組件三",  componentId: "three",},{  componentName: "動態組件四",  componentId: "four",},      ],    };  },};</script><style lang="less" scoped>#app {  width: 100%;  height: 100vh;  box-sizing: border-box;  padding: 50px;  .top {    width: 100%;    height: 80px;    display: flex;    justify-content: space-around;    .crad {      width: 20%;      height: 80px;      line-height: 80px;      text-align: center;      background-color: #fff;      border: 1px solid #e9e9e9;    }    .highLight {      box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);      transform: translate3d(0, -1px, 0);    }  }  .bottom {    margin-top: 20px;    width: 100%;    height: calc(100% - 100px);    border: 3px solid pink;    display: flex;    justify-content: center;    align-items: center;  }}</style>

總結

到此這篇關于vue使用動態組件實現TAB切換效果的文章就介紹到這了,更多相關vue動態組件實現TAB切換內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 美女国产一区 | 国产午夜免费一区二区三区 | 日产免费线路一页二页 | 黄色片在线观看视频 | 国产级a爱做片免费观看 | 日韩免费高清视频网站 | 欧美国产亚洲一区二区三区 | 中文字幕无线码一区二区三区 | 国产一区二区三区福利 | 黄在线| 亚洲国产日韩综合久久精品 | 亚洲欧洲日韩天堂无吗 | 92国产福利午夜757小视频 | 亚洲综合欧美色综合小说 | 成人伊人青草久久综合网破解版 | 亚洲国产精品久久久久婷婷老年 | 91青青草视频 | 精品视频免费 | 色综合一区二区三区 | aaa黑人一级毛片 | 国产tv在线观看 | 亚洲视频一区二区 | 91久久国产露脸国语对白 | 亚洲国产激情一区二区三区 | 国产成人无精品久久久 | 亚洲国产欧美精品一区二区三区 | 午夜视频网址 | 1000部未满岁18在线观看污 | 亚洲巨乳自拍在线视频 | 免费视频不卡一区二区三区 | 五月天婷婷视频 | 成人午夜视频在线 | 全部费免一级毛片不收费 | miya亚洲私人影院在线 | 日本美女一区二区 | 日韩在线精品视频 | 亚洲国产成人久久77 | 成人午夜在线播放 | 91视频国内| 欧美一区二三区 | 国产精品视频人人做人人爱 |