html css 等比例缩放

来自:https://blog.csdn.net/chenrui310/article/details/129365208 侵删

         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);

当开发前端页面在分辨率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;
这样就可以了
————————————————
版权声明:本文为CSDN博主「chenrui310」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/chenrui310/article/details/129365208

posted @ 2023-05-10 16:31  abcByme  阅读(564)  评论(0编辑  收藏  举报