<template>
  <div>
    <button @click="changeView">切换视图</button>
    <transition name="fade" mode="out-in">
      <component :is="currentView"></component>
    </transition>
  </div>
</template>
<script>
import ComponentA from './ComponentA.vue'
import ComponentB from './ComponentB.vue'

export default {
  components: {
    ComponentA,
    ComponentB
  },
  data() {
    return {
      currentView: 'ComponentA'
    }
  },
  methods: {
    changeView() {
      this.currentView = this.currentView === 'ComponentA' ? 'ComponentB' : 'ComponentA'
    }
  }
}
</script>
<style>
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.5s;
}
.fade-enter,
.fade-leave-to {
  opacity: 0;
}
</style>
Vue.js 切换组件视图示例

原文地址: https://www.cveoy.top/t/topic/ohX2 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录