vue2的scale方式适配大屏

代码

js 复制代码
mounted(){
    //初始化自适应  ----在刚显示的时候就开始适配一次
    handleScreenAuto();
    //绑定自适应函数   ---防止浏览器栏变化后不再适配
    window.onresize = () => handleScreenAuto();
},
destroyed(){
    window.onresize = null;
},
methods: {
    //数据大屏自适应函数
    const handleScreenAuto = (): void => {
        const designDraftWidth = 1920;//设计稿的宽度
        const designDraftHeight = 960;//设计稿的高度
        //根据屏幕的变化适配的比例
        const scale = document.documentElement.clientWidth / document.documentElement.clientHeight < designDraftWidth / designDraftHeight ?
            (document.documentElement.clientWidth / designDraftWidth) :
            (document.documentElement.clientHeight / designDraftHeight);
        //缩放比例
        (document.querySelector('#screen') as any).style.transform = `scale(${scale}) translate(-50%)`;
    }
}
html 复制代码
<template>
    <div className="screen-wrapper">
        <div className="screen" id="screen">

        </div>
    </div>
</template>
css 复制代码
    .screen-root {
    height: 100%;
    width: 100%;

    .screen {
        display: inline-block;
        width: 1920px;
    / / 设计稿的宽度 height: 960 px;
    / / 设计稿的高度 transform-origin: 0 0;
        position: absolute;
        left: 50%;
    }
}

将上述生命周期和methods中的代码复制,然后在id为screen的div中编写数据大屏即可。

缺点:

  • 内部组件如果用了鼠标坐标点这些,会有偏移的。比如 slider滑块这些依赖 clientX 这些的。
  • 如果大屏内存在地图组件的交互,存在点错位问题
相关推荐
叶小秋1 分钟前
React 进阶:一个优雅的弹窗管理 Hook 实现
前端·react.js
华洛2 分钟前
聊一下MCP,希望能让各位清醒一点吧🧐
前端·javascript·vue.js
凯哥19702 分钟前
Sciter.js 的前世今生
前端
北京_宏哥2 分钟前
🔥PC端自动化测试实战教程-6-pywinauto 打印和保存控件菜单树结构之ElementNotFoundError(详细教程)
前端·windows·python
江城开朗的豌豆4 分钟前
CSS篇:前端开发者必须掌握的CSS核心知识:选择器与优先级详解
前端·css·面试
北京_宏哥5 分钟前
🔥PC端自动化测试实战教程-5-pywinauto 操作PC端应用程序窗口 - 下篇(详细教程)
前端·windows·python
星辰梦彼岸7 分钟前
JavaScript 内存管理:从垃圾回收机制到内存泄漏
前端·javascript
前端布鲁伊8 分钟前
【前端面试必杀技】一文吃透前端截图实现原理,让面试官对你刮目相看!
前端
光影少年9 分钟前
vue事假机制都有哪些
前端·vue.js
和和和9 分钟前
关于webpack我们应该知道的知识
前端·javascript·面试