可视化大屏设计尺寸_Vue 大屏可视化-屏幕自适应(保持设计尺寸比例)

本文介绍了使用Vue实现大屏页面的屏幕自适应方法,旨在保持设计尺寸比例。通过配置文件设置大屏设计尺寸,然后利用JavaScript进行窗口大小监听和调整,确保元素在不同屏幕尺寸下按比例缩放。文章提供了具体实现步骤和代码示例,适用于需要处理大屏可视化项目的人群。
摘要由CSDN通过智能技术生成

最近在用VUE写大屏页面,遇到屏幕自适应问题,根据设计的尺寸,在各种屏幕尺寸下自适应,保持显示比例不变,经过几天摸索,终于达到了效果,希望为还在这问题困扰的提供点帮助

铺满全屏效果见Vue 大屏可视化 铺满全屏

1. 在配置文件设置大屏设计的尺寸1920*1080

//appConfig.js

export default{

screen:{

width:1920,

height:1080,

scale:20

}//大屏设计宽高

}

2. 定义resetScreenSize.js

import appConfig from '../config/base'

export function pageResize(callback) {

let init = () => {

console.log(window.innerHeight + "," + window.innerWidth);

let _el = document.getElementById('app');

let hScale = window.innerHeight / appConfig.screen.height;

let wScale = window.innerWidth / appConfig.screen.width;

let pageH = window.innerHeight;

let pageW = window.innerWidth;

let isWider = (window.innerWidth / window.innerHeight) >= (appConfig.screen.width / appConfig.screen.height);

console.log(isWider);

if (isWider) {

_el.style.height = window.innerHeight+'px';// '100%';

_el.style.width = pageH * appConfig.screen.width / appConfig.screen.height + 'px';

_el.style.top='0px';

_el.style.left=(window.innerWidth -pageH * appConfig.screen.width / appConfig.screen.height)*0.5+'px';

console.log(_el.style.width + "," + _el.style.height)

}

else {

_el.style.width = window.innerWidth+'px';// '100%';

_el.style.height = pageW * appConfig.screen.height / appConfig.screen.width + 'px';

_el.style.top= 0.5*(window.innerHeight-pageW * appConfig.screen.height / appConfig.screen.width)+'px';

_el.style.left='0px';

console.log(_el.style.height);

console.log(_el.style.top);

}

document.documentElement.style.fontSize = (_el.clientWidth / appConfig.screen.scale) + 'px';

}

var resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize';

window.addEventListener(resizeEvt, init, false);

document.documentElement.addEventListener('DOMContentLoaded', init, false);

init()

}

3 使用方式

main.js 引入

import appConfig from './config/base.js';

Vue.prototype.appConfig=appConfig;

app.Vue  在mounted函数引入

import {pageResize} from './utils/resetScreenSize'

export default {

name: 'App',

data(){

return{

}

},

mounted(){

pageResize();

console.log('pageResize');

}

}

组件中样式 lang="stylus"

.mc{

display :flex;

flex-direction :column;

align-content :center;

justify-content :center;

display: flex;

flex: 1 1 auto;

flex-direction: column;

padding:(15/96)rem;

}

.leftC{

width :(410/96)rem;

}

.centerC{

width :(1060/96)rem;

}

.rightC{

width :(450/96)rem;

}

其中 96为 配置文件中1920/20得来,这样不用在进行各种换算了

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值