html css 等比例缩放(记录)

 		let cw = 1920,ch = 1080//默认
        let body = document.getElementById('body')
        body.style.width = `${cw}px`
        body.style.height = `${ch}px`

        // 对body进行缩放
        function windowResize() {
            // 窗口宽高
            let w = window.innerWidth,
                h = window.innerHeight
            // 缩放比例
            let r = w / cw < h / ch ? w / cw : h / ch

            body.style.transform = `scale( ${r})`
            // 因为scale是以body的原中心点为基准进行缩放,所以缩放之后需要调整外边距,使其位于窗口的中心位置
            body.style.marginLeft = (-(cw - r * cw) / 2 + (w - r * cw) / 2) + 'px'
            body.style.marginTop = (-(ch - r * ch) / 2 + (h - r * ch) / 2) + 'px'
            body.style.marginBottom = (-(h > ch ? h : ch - r * ch)) + 'px'
            body.style.marginRight = (-(w > cw ? w : cw - r * cw)) + 'px'
        }

       window.addEventListener("load", windowResize())
        // 监听窗口尺寸变化
        window.addEventListener('resize', windowResize);

欢迎使用Markdown编辑器

当开发前端页面在分辨率1920的情况下,需要切换到小屏,有种方法是可以对屏幕比例进行缩放,通过css3属性transform可以自适应屏幕分辨率大小

var s;
function resize() {
  s = window.screen.width / 1920;
  document.body.style.transformOrigin = '0 0';
  document.body.style.transform = 'scale(' + s + ',' + s + ')';
  document.body.style.width = window.innerWidth / s + 'px';
  document.body.style.height = window.innerHeight / s + 'px';
}
window.onresize = function () {
  resize();
}
resize();

通过计算屏幕分辨率比例,对当前页面进行比例缩放。

但是这会有一个问题,就是如果页面中有定位,缩放后定位的位置会跑偏。那是因为,如果使用定位left,top来固定窗口位置时候,body的大小改变会对它的children的定位产生影响,并且定位的弹框大小没有对应缩放。

发现一个简单的方法
 

s = window.screen.width / 1920;
document.body.style.zoom = s;

这样就可以了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值