Vue2.x动态组件的使用实现组件整合大屏展示

Vue2.x动态组件的使用实现组件整合大屏展示

一、问题

  • 项目中开发多个可视化的页面(组件),现需要根据选择的数据和屏幕的配置数据将多个页面整合在同一个页面内,并且根据配置数据划分占比以及位置关系(横向位置,垂直高度统一,横向宽度根据配置数据的占比进行划分)
  • 大致效果如图所示,横向排列,按照数据中小屏组件数据的先后顺序进行排列即可:
    在这里插入图片描述

二、解决

  • 解决思路,主要利用Vue的动态组件,配合CSSflex布局方式实现

  • 首先最好将大屏的页面路由放在一级路由下单独的一个界面,这样大屏界面的样式不会受到其它界面的影响

  • 根据返回的数据动态设置屏幕的html部分代码如下,利用component动态组件,通过is属性绑定所需组件的名称,这里的名称与import引入的组件名称保持一致

    <template>
      <div
        class="big-screen"
        :style="`width:${screenWidth}px;height:${screenHeight}px;`"
      >
        <div class="big-screen-title">
          <h1>{{screenTitle}}</h1>
        </div>
        <!-- 此处减去标题的高度50px -->
        <div
          class="model-item"
          v-for="item in screenSet"
          :key="item.key"
          :style="`height:${screenHeight-50}px;flex:${item.screenProportion};`"
        >
          <component :is="item.componetType"></component>
        </div>
      </div>
    </template>
    
  • datacomponents中的部分参数如下:

    data() {
    	return{
          screenTitle: '--', // 大屏标题
          screenWidth: '100', // 当前大屏的宽度默认100px
          screenHeight: '100', // 当前大屏的高度默认100px
          screenSet: [], // 大屏配置中每个小屏配置数据
    	}
    },
    components: {
    	InsideTopo,
    	InsideMap,
    	InsideMatrix
    }
    
  • CSS部分代码如下,利用flex布局,动态划分所占的份数

    <style scoped lang="less">
    .big-screen {
      background: #000000;
      display: flex;
      justify-content: flex-start;
      position: relative;
      // 大屏标题
      .big-screen-title {
        width: 100%;
        height: 50px;
        position: absolute;
        display: flex;
        justify-content: center;
        align-items: center;
        background: #000000;
        h1 {
          font-size: 36px;
          color: #ddfaff;
          letter-spacing: 3px;
          text-shadow: 0px 3px 10px rgb(0 147 255 / 85%);
        }
      }
      .model-item {
        margin-top: 50px;
      }
    }
    </style>
    
  • JavaScript部分将所需要的组件引入,根据需求逻辑,将组件和配置信息存入数组中,在大屏页面created的钩子函数中初始化数组,之后动态组件会根据数组内容将组件进行渲染,组件位置问题也根据数组的中的顺序从左到右进行展示

    // 引入可视化组件
    import InsideTopo from '@/pages/visual/InsideTopo'
    import InsideMap from '@/pages/visual/InsideMap'
    import InsideMatrix from '@/pages/visual/InsideMatrix'
    
  • 数组的大致结构如下,其中componentType为引入的组件名称,screenProportion是该组件所占的大小(flex)的值,保证动态组件componentis属性绑定组件名与引入组件名同名即可,这里如何操作数组screenSet配置小屏就按需求操作即可,下面是screenSet的数据结构,仅作参考不做赘述
    在这里插入图片描述

  • 最终效果如下:
    在这里插入图片描述
    这样问题就解决了,如果有更好的方法欢迎补充讨论🌈

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3 中使用大屏数据可视化库 DataV 的步骤如下: 1. 首先,确保你已经在项目中安装了 Vue 3 及其相应的依赖。可以使用 Vue CLI 或其他工具来初始化项目并生成基础的目录结构和配置文件。 2. 在你的前端项目中,使用 npm 或 yarn 安装 DataV 插件。 可以使用以下命令进行安装: ``` npm install @jiaminghi/data-view ``` 或 ``` yarn add @jiaminghi/data-view ``` 3. 在你的 Vue 组件中引入 DataV 插件并使用它。 在你的组件中,使用 import 语句将 DataV 引入: ``` import DataV from '@jiaminghi/data-view' ``` 然后,在你的模板中使用 DataV 的组件展示大屏数据可视化: ``` <template> <dataVComponent></dataVComponent> </template> ``` 4. 根据 DataV 的文档和示例,按照你的需求来配置和使用 DataV 的组件和功能。可以参考 DataV 的官方文档和示例代码来了解如何使用不同的组件和功能来展示大屏数据可视化效果。 如果你在使用 TypeScript 进行开发,还需要在 `shims-vue.d.ts` 文件中添加以下声明,以便让 TypeScript 识别 DataV 的模块: ``` declare module '@jiaminghi/data-view' ``` 这样 TypeScript 就能正确地识别并使用 DataV 的模块。 总结: 1. 确保项目中安装了 Vue 3 及其依赖。 2. 使用 npm 或 yarn 安装 DataV 插件。 3. 在 Vue 组件中引入 DataV 插件。 4. 配置和使用 DataV 的组件和功能来展示大屏数据可视化效果。 请根据你的具体需求和项目情况进行相应的配置和使用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [vue3使用大屏dataV详细教程](https://blog.csdn.net/weixin_51958960/article/details/128873162)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [vue整合SSM项目实战](https://download.csdn.net/download/m0_55755339/88241603)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值