大屏利用rem自适应

大屏响应式开发

使用rem适应不同分辨率

  1. 在head标签中调用自动设置html的font-size的方法 并添加页面刷新监听事件
    注意如果在body后面才调用 页面刷新会有一瞬间的变形 因为在文档加载完成前就需要调用,设置对应的宽高样式
  <script>
    setHtmlFontSize();
    window.addEventListener(
      "resize", setHtmlFontSize, false
    );
  </script>
  1. js中定义的方法:
function setHtmlFontSize() {
    let docEle = document.documentElement;
    let screenRatioByDesign = 16 / 9
    let screenRatio = docEle.clientWidth / docEle.clientHeight;
    let fontSize = ((screenRatio > screenRatioByDesign ? screenRatioByDesign / screenRatio : 1) * docEle
        .clientWidth) / 10;
    docEle.style.fontSize = fontSize.toFixed(3) + "px";
}

设计稿为1920X1080 因此比例是16/9,我的项目是缩小10倍 ,最后的结果 fontsize是192。即width: 10rem ,height:5.625rem,其他样式中的px都换成rem

参考:
关于大屏利用rem自适应
大屏上的全屏页面的自适应适配方案
vue中使用rem布局解析+大屏自适应

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值