Vuejs:component动态组件的使用示例

简介: Vuejs:component动态组件的使用示例

image.png

文档

component动态组件很适合在不同组件之间切换,相比v-if判断,要优雅得多

项目结构

$ tree -I node_modules
.
├── package.json
└── src
    ├── App.vue
    ├── components
    │   ├── ComponentA.vue
    │   ├── ComponentB.vue
    │   └── ComponentC.vue
    └── main.js

依赖 package.json

{
  "scripts": {
    "dev": "vue-cli-service serve",
    "build": "vue-cli-service build"
  },
  "dependencies": {
    "vue": "^2.6.14"
  },
  "devDependencies": {
    "@vue/cli-service": "^5.0.8",
    "vue-template-compiler": "^2.6.14",
    "less": "^4.0.0",
    "less-loader": "^8.0.0"
  }
}

入口文件 main.js

import Vue from "vue";
import App from "./App.vue";
new Vue({
  el: "#app",
  render: (h) => h(App),
});

组件 ComponentA.vue

<template>
  <div class="">ComponentA</div>
</template>
<script>
// created at 2023-03-31
export default {
  name: "ComponentA",
};
</script>
<style lang="less"></style>

组件 ComponentB.vue

<template>
  <div class="">ComponentA</div>
</template>
<script>
// created at 2023-03-31
export default {
  name: "ComponentA",
};
</script>
<style lang="less"></style>

组件 ComponentC.vue

<template>
  <div class="">ComponentC</div>
</template>
<script>
// created at 2023-03-31
export default {
  name: "ComponentC",
};
</script>
<style lang="less"></style>

App.vue

<template>
  <div class="app-container">
    <h2>Vue.js component动态组件示例</h2>
    <!-- tabs -->
    <div class="tabs">
      <div
        v-for="item in componentConfigs"
        class="tab-item"
        :class="{ 'tab-item--active': item.value == tab }"
        @click="handleTabClick(item)"
      >
        {{ item.label }}
      </div>
    </div>
    <!-- content -->
    <div class="content">
      <component v-bind:is="currentComponent"></component>
    </div>
  </div>
</template>
<script>
// created at 2022-12-26
import ComponentA from "./components/ComponentA.vue";
import ComponentB from "./components/ComponentB.vue";
import ComponentC from "./components/ComponentC.vue";
const componentConfigs = [
  {
    component: ComponentA,
    value: "A",
    label: "组件 A",
  },
  {
    component: ComponentB,
    value: "B",
    label: "组件 B",
  },
  {
    component: ComponentC,
    value: "C",
    label: "组件 C",
  },
];
export default {
  name: "App",
  data() {
    return {
      tab: "A",
      componentConfigs,
    };
  },
  computed: {
    currentComponent() {
      return componentConfigs.find((item) => item.value == this.tab).component;
    },
  },
  methods: {
    handleTabClick(item) {
      this.tab = item.value;
    },
  },
  created() {},
};
</script>
<style lang="less">
body {
  display: flex;
  justify-content: center;
}
.app-container {
  text-align: center;
}
.tabs {
  display: flex;
  justify-content: center;
  border: 1px solid #808080;
  border-bottom: none;
}
.tab-item {
  width: 200px;
  line-height: 40px;
  text-align: center;
  background-color: #808080;
  color: #fff;
  cursor: pointer;
}
.tab-item--active {
  background-color: #fff;
  color: #000;
}
.content {
  line-height: 500px;
  text-align: center;
  border: 1px solid #808080;
}
</style>

完整代码:https://github.com/mouday/vue-demo/tree/main/packages/vue-component

在线示例:https://mouday.github.io/vue-demo/packages/vue-component/dist/index.html


相关文章
|
4天前
|
JavaScript 数据库
ant design vue日期组件怎么清空 取消默认当天日期
ant design vue日期组件怎么清空 取消默认当天日期
|
4天前
|
JavaScript C++
vue高亮显示组件--转载
vue高亮显示组件--转载
9 0
|
4天前
|
JavaScript 前端开发 开发者
Vue的事件处理机制提供了灵活且强大的方式来响应用户的操作和组件间的通信
【5月更文挑战第16天】Vue事件处理包括v-on(@)指令用于绑定事件监听器,如示例中的按钮点击事件。事件修饰符如.stop和.prevent简化逻辑,如阻止表单默认提交。自定义事件允许组件间通信,子组件通过$emit触发事件,父组件用v-on监听并响应。理解这些机制有助于掌握Vue应用的事件控制。
18 4
|
4天前
|
JavaScript 前端开发 UED
Vue class和style绑定:动态美化你的组件
Vue class和style绑定:动态美化你的组件
|
4天前
|
JavaScript
vue封装面包屑组件
vue封装面包屑组件
7 0
|
4天前
|
JavaScript 前端开发 API
深入理解vue组件生命周期,你一定要看到最后,最后有深入探讨
深入理解vue组件生命周期,你一定要看到最后,最后有深入探讨
|
4天前
|
JavaScript Go
VUE3+vite项目中动态引入组件和异步组件
VUE3+vite项目中动态引入组件和异步组件
|
4天前
|
缓存 算法 JavaScript
vue中组件保活<keep-alive>的使用
vue中组件保活<keep-alive>的使用
|
4天前
|
JavaScript 前端开发 UED
教你用vue自定义指令做一个组件的遮罩层loading效果
教你用vue自定义指令做一个组件的遮罩层loading效果
|
4天前
|
存储 JavaScript 前端开发
用Vue写一个简单好看的菜单组件(Vue实战系列)
用Vue写一个简单好看的菜单组件(Vue实战系列)