vue3使用策略模式管理动态组件的扩展性
创始人
2024-11-14 18:34:25
0

这里写自定义目录标题

  • 背景
  • 目标
  • 步骤
    • 1. 创建组件策略
      • 1.1 定义按钮组件
      • 1.2 创建策略管理器
    • 2.创建策略上下文
    • 3.使用组件
  • 总结

背景

举例,假设在业务中有三种类型的组件button-default.vuebutton-primary.vuebutton-warning.vue 根据接口返回的类型type来控制展示。通常,我们会在代码中根据type条件判断,来控制组件的展示。但是,可预见的未来,业务类型会不断增长,每次扩展类型,都去组件使用位置去修改代码,不是很友好。所以,思考可以使用策略模式的方式来管理组件。

目标

要使用策略模式管理 button-default.vue、button-primary.vue 和 button-warning.vue 这三个组件,并且能够根据传入的 type 参数渲染对应的组件

步骤

1. 创建组件策略

首先,创建一个策略管理器,这个管理器将负责根据传入的 type 渲染正确的组件。

1.1 定义按钮组件

button-default.vue

        

button-primary.vue

      

button-warning.vue

       

1.2 创建策略管理器

创建一个工厂函数来管理不同类型的按钮组件。

import { defineComponent, Component } from 'vue'; import ButtonDefault from './button-default.vue'; import ButtonPrimary from './button-primary.vue'; import ButtonWarning from './button-warning.vue';  // 定义策略映射类型 type ButtonType = 'default' | 'primary' | 'warning';  const buttonComponents: Record = {   default: ButtonDefault,   primary: ButtonPrimary,   warning: ButtonWarning, };  // 获取按钮组件 export function getButtonComponent(type: ButtonType) {   return buttonComponents[type] || buttonComponents.default; }  

2.创建策略上下文

在 Vue 组件中使用策略管理器来动态选择并渲染按钮组件。

      

3.使用组件

在应用中,使用 DynamicButton 组件来渲染不同类型的按钮。

    

总结

这种方法有效提高了组件的灵活性和可维护性

相关内容

热门资讯

4分钟理解!gg发牌控制(透视... 4分钟理解!gg发牌控制(透视)就是真的有挂(2022已更新)(哔哩哔哩)1、进入游戏-大厅左侧-新...
八分钟理解!(哈糖大菠萝)软件... 八分钟理解!(哈糖大菠萝)软件透明挂黑科技,wpk发牌这离谱,必胜教程(有挂普及)-哔哩哔哩1、wp...
5分钟了解!wepower辅助... 5分钟了解!wepower辅助软件(透明黑科技)本来真的有挂(2024已更新)(哔哩哔哩)1、金币登...
透视长期!aapoker软件a... 透视长期!aapoker软件app,德扑之心免费透视,wepoker作弊辅助挂(有挂脚本)aapok...
四分钟了解!(aaPOKER)... 四分钟了解!(aaPOKER)软件透明挂黑科技,gg扑克有辅助,科技教程(有挂揭秘)-哔哩哔哩;1、...
3分钟安装!线上德州辅助软件有... 3分钟安装!线上德州辅助软件有用吗(黑科技)就是真的有挂(2022已更新)(哔哩哔哩);1、完成线上...
透视大厅房!智星德州有挂吗,w... 透视大厅房!智星德州有挂吗,wepokre辅助透视软件,wepoker透视软件下载(有挂APP);一...
八分钟推荐!德扑之星如何开房间... 八分钟推荐!德扑之星如何开房间(透视)原来真的有挂(2025已更新)(哔哩哔哩)1、上手简单,内置详...
5分钟体悟!(约局吧)软件透明... 5分钟体悟!(约局吧)软件透明挂黑科技,wpk微扑克俱乐部,可靠教程(有挂科研)-哔哩哔哩;wpk微...
透视俱乐部!wepoke软件透... 透视俱乐部!wepoke软件透明挂辅助,wpk模拟器是什么,德扑之星是不是有人用挂(有挂脚本)透视俱...