可视化大屏的几种适配方案

一、css3 transform:scale()方法

在项目中直接使用设计稿中px单位进行开发即可,会对body内所有元素进行缩放,从而不会让echarts图表超出画布;

需要注意的是,绑定resize事件一定别忘了防抖,页面销毁别忘了移除监听事件

我们直接使用时如果显示屏幕并不是16:9,那么我们的项目就可能会出现空白,解决方案如下:

function resize() {
          var ratioX = $(window).width() / 1920; //此处的宽高根据自己屏幕的比例修改即可
          var ratioY = $(window).height() / 1080;
          $("body").css({
              transform: "scale(" + ratioX + "," + ratioY + ")",
              transformOrigin: "left top",
              backgroundSize: "100% 100%"
          });
          $("html").css({'overflow':'hidden'})
}

二、rem+grid(或百分比)

当页面首次加载时,判断视口的宽高,如果视口的宽/高 > 16/9 则说明视口宽度比较设计图宽,实际的显示宽度应该等于视口的高度*16/9。

如果视口的宽/高 < 16/9 则说明视口高度比设计图高,实际的显示宽度应该等于视口的宽度,显示高度应等于视口宽度 / (16/9)。

然后设置 font-size: pageWidth / 100 px,这样就可以做到100rem等于100% width,之后所有大小的设置都通过rem来做,这样就可以做到适配任意比例的大屏了。

<script>
  const clientWidth = document.documentElement.clientWidth
  const clientHeight = document.documentElement.clientHeight
  window.pageWidth = clientWidth / clientHeight > 16 / 9 ? clientHeight * (16 / 9) : clientWidth
  const pageHeight = pageWidth / (16 / 9)
  const string = `<style>html{
      font-size: ${pageWidth / 100}px
    }</style>`
  document.write(string)
 
  root.style.width = pageWidth + 'px'
  root.style.height = pageHeight + 'px'
  root.style.marginTop = (clientHeight - pageHeight) / 2 + 'px'
</script>

三、vw和vh适配方案

屏幕视口宽度 = 100vw,屏幕视口高度 = 100vh

vw和vh也是css中标准的单位,和px,rem, %一样 vw和vh适配方案,按照设计稿的尺寸,将px按比例计算转为vw和vh

那么我们需要封装一个处理函数,让它帮我自动计算,这里用到了scss

//使用scss的math函数,https://sass-lang.com/documentation/breaking-changes/slash-div
@use "sass:math"; 
 
 
//默认设计稿的宽度
$designWidth:1920;
//默认设计稿的高度
$designHeight:1080;
 
 
//px转为vw的函数
@function vw($px) {
  @return math.div($px , $designWidth) * 100vw;
}
 
//px转为vh的函数
@function vh($px) {  
  @return math.div($px , $designHeight) * 100vh;
}

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/115236.html<

(0)
运维的头像运维
上一篇2025-02-18 01:11
下一篇 2025-02-18 01:12

相关推荐

  • 企业入云端 别一味纠结安全问题

     作为一种省钱的技术,云计算以“咬定青山不放松”的坚韧,给企业带来访问更多的存储容量和计算资源等益处。但即使将数据和工作负担迁移到云可以带来诸多好处,仍有一些公司对云的安…

  • 企业安全管理的“六脉神剑”

    当考虑确定计算系统、数据和网络的可用性和完整性控制时,与可考虑潜在机会授权的管理员相比,普通用户拥有更少的特权。系统管理员、执行备份的操作人员、数据库管理员、维修技师甚至帮助台支持…

  • 黑客瞄准Facebook用户出新招

    3月18日,杀毒软件厂商McAfee周三表示,黑客们在网络上投放了大批针对Facebook四亿用户的带病毒垃圾邮件,旨在窃取用户银行密码等机密信息。 McAfee称,邮件提示所有F…

  • 奇安信世界互联网大会发布全新品牌形象

     三国演义》赤壁之战中有一场智斗:诸葛亮乘周瑜与曹仁激战,命赵子龙夺南郡,大捷后取得守将虎符,用虎符调开曹兵,兵不血刃再夺两城。这场智斗中的关键道具——虎符,穿越千年来到…

  • 盘点:2020年最酷的10家网络安全初创公司

    应对明日威胁 近几年涌现了一批出色的网络安全公司,致力于解决各种网络安全问题,从自动遵守复杂的全球隐私法规,到保护应用安全以及将应用从网络中隔离出来,发现黑客最有可能从哪发起攻击。…

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注