html页面排版会乱,窗口缩放导致页面排版错乱的解决方法

简单的说就是设置body的宽度,那么如何动态的获取浏览器减去侧边滚动条之后的宽度,原理就是通过创建一个带有滚动条的div(也就是overflow:scroll),利用offsetWidth-clientWidth得到滚动条的宽度,再利用window.screen.availWidth减去滚动条的宽度即可得到浏览器除了滚动条以外的宽度,body再设置该宽度,即可解决缩放排版错乱的问题。

代码展示如下:

function setBodyWidth(){

var barWidthHelper=document.createElement('div');

barWidthHelper.style.cssText="overflow:scroll; width:100px; height:100px;";

document.body.appendChild(barWidthHelper);

var barWidth=barWidthHelper.offsetWidth-barWidthHelper.clientWidth;

document.body.removeChild(barWidthHelper);

var bodyWidth=window.screen.availWidth-barWidth;

return bodyWidth;

}

$(document).ready(

function(){

var bodyWidth=setBodyWidth()+"px";

//document.body.style.width=bodyWidth;

$("body").css("width",bodyWidth);

}

);

window.screen.availHeight与window.screen.height的区别就是一个任务栏高度的区别。

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值