Vue3 数据可视化屏幕大屏适配 页面自适应 响应式 数据大屏 大屏适配

介绍

数据可视化大屏应用时,页面的自适应和响应式设计至关重要。这些技术能够确保应用能够根据不同屏幕尺寸、设备分辨率和窗口变化自动调整布局和显示内容,提升用户体验。

全屏适配

无论大屏还是小屏完美设配

工具

javascript 复制代码
import { onBeforeUnmount, onMounted, ref } from 'vue';

/**
 * useResponsiveScale Hook - 用于实现自适应缩放功能
 * 
 * @param {number} baseWidth 设计稿的宽度,默认值为 1920
 * @param {number} baseHeight 设计稿的高度,默认值为 1080
 * @returns {object} 返回包含 appRef 的对象,appRef 用于绑定需要缩放的元素
 */
export function useResponsiveScale(baseWidth = 1920, baseHeight = 1080) {
    // 定义响应式变量,保存缩放的定时器
    const drawTiming = ref(null);

    // 定义响应式变量,保存缩放的宽度和高度
    const scale = ref({
        width: '1',
        height: '1',
    });

    // 计算设计稿的宽高比
    const baseProportion = parseFloat((baseWidth / baseHeight).toFixed(5));

    // 用于绑定需要进行缩放的元素的 ref
    const appRef = ref(null);

    /**
     * 计算并应用缩放比例
     */
    const calcRate = () => {
        if (!appRef.value) return; // 如果 appRef 没有被绑定,直接返回

        // 计算当前窗口的宽高比
        const currentRate = parseFloat((window.innerWidth / window.innerHeight).toFixed(5));

        // 如果当前窗口比设计稿更宽,按宽度缩放
        if (currentRate > baseProportion) {
            scale.value.width = ((window.innerHeight * baseProportion) / baseWidth).toFixed(5);
            scale.value.height = (window.innerHeight / baseHeight).toFixed(5);
            appRef.value.style.transform = `scale(${scale.value.width}, ${scale.value.height}) translate(-50%, -50%)`;
        } else {
            // 如果当前窗口比设计稿更高,按高度缩放
            scale.value.height = ((window.innerWidth / baseProportion) / baseHeight).toFixed(5);
            scale.value.width = (window.innerWidth / baseWidth).toFixed(5);
            appRef.value.style.transform = `scale(${scale.value.width}, ${scale.value.height}) translate(-50%, -50%)`;
        }
    };

    /**
     * 处理窗口 resize 事件,防止频繁触发
     */
    const resize = () => {
        clearTimeout(drawTiming.value); // 清除上一次的定时器
        drawTiming.value = setTimeout(() => {
            calcRate(); // 在延迟后计算缩放比例
        }, 150);
    };

    // 在组件挂载时执行计算,并监听窗口的 resize 事件
    onMounted(() => {
        calcRate(); // 初始化时计算缩放比例
        window.addEventListener('resize', resize); // 监听 resize 事件
    });

    // 在组件卸载时移除 resize 事件监听器
    onBeforeUnmount(() => {
        window.removeEventListener('resize', resize);
    });

    // 返回 appRef,以便在组件中绑定需要缩放的元素
    return {
        appRef
    };
}

模板

html 复制代码
  <div class="box" ref="appRef">
    <div class="draw"></div>
    <div class="draw"></div>
    <div class="draw"></div>
  </div>

样式

css 复制代码
.box{
  color: #d3d6dd;
  width: 1920px;
  height: 1080px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transform-origin: left top;
  overflow: hidden;
}

导入

javascript 复制代码
import { useResponsiveScale } from './utils/rsponsiveScale.js';
const { appRef } = useResponsiveScale();
相关推荐
低频电磁之道2 分钟前
解决 Windows C++ DLL 导出类不可见的编译错误
c++·windows
张np4 分钟前
java进阶-Dubbo
java·dubbo
汽车仪器仪表相关领域5 分钟前
NHFID-1000型非甲烷总烃分析仪:技术破局,重构固定污染源监测新体验
java·大数据·网络·人工智能·单元测试·可用性测试·安全性测试
武子康7 分钟前
大数据-264 实时数仓-MySQL Binlog配置详解:从原理到实践|数据恢复与主从复制实战
大数据·hadoop·后端
一叶飘零_sweeeet7 分钟前
深入理解 AQS:从架构到实现,解锁 Java 并发编程的核心密钥
java·aqs
倾颜10 分钟前
接入 MCP,不一定要先平台化:一次 AI Runtime 的实战取舍
前端·后端·mcp
wechat_Neal12 分钟前
Golang的车载应用场景
开发语言·后端·golang
军军君0113 分钟前
Three.js基础功能学习十八:智能黑板实现实例五
前端·javascript·vue.js·3d·typescript·前端框架·threejs
Moment14 分钟前
AI全栈入门指南:一文搞清楚NestJs 中的 Controller 和路由
前端·javascript·后端
禅思院15 分钟前
前端架构演进:基于AST的常量模块自动化迁移实践
前端·vue.js·前端框架