数据大屏使用scale缩放

(function (win) {
        var bodyStyle = document.createElement('style')
        bodyStyle.innerHTML = `body{width:1920px; height:1080px!important;}`
        // 创建一个style元素,并将其innerHTML设置为“body{width:1920px; height:1080px!important;}”,这将使body元素的宽度为1920像素,高度为1080像素,并且!important规则将覆盖任何其他可能存在的样式规则
        document.documentElement.firstElementChild.appendChild(bodyStyle)//将bodyStyle节点添加到HTML文档的根节点下的第一个子节点中。

        function refreshScale() {
          let docWidth = document.documentElement.clientWidth;//浏览器窗口中可见宽度
          let docHeight = document.documentElement.clientHeight;//浏览器窗口中可见高度
          // console.log(docHeight,docWidth);
          var designWidth = 1920,
            designHeight = 1080,
            widthRatio = docWidth / designWidth,
            heightRatio = docHeight / designHeight;
          document.body.style = `transform:scale(${widthRatio},${heightRatio});transform-origin:left top;`;// 设置缩放原点transform-origin: left top;
          // 应对浏览器全屏切换前后窗口因短暂滚动条问题出现未占满情况
          setTimeout(function () {
            var lateWidth = document.documentElement.clientWidth,
              lateHeight = document.documentElement.clientHeight;
            if (lateWidth === docWidth) return;

            widthRatio = lateWidth / designWidth
            heightRatio = lateHeight / designHeight
            document.body.style = "transform:scale(" + widthRatio + "," + heightRatio + ");transform-origin:left top;"
            // 设置缩放原点transform-origin: left top;
            // 地图适配缩放比例
          }, 0)
        }
        refreshScale()

        win.addEventListener("pageshow", function (e) {
          if (e.persisted) { // 浏览器后退的时候重新计算
            refreshScale()
          }
        }, false);
        win.addEventListener("resize", refreshScale, false);
      })(window)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值