首頁 >web前端 >css教學 >CSS網頁版面錯位:CSS寬度計算

CSS網頁版面錯位:CSS寬度計算

高洛峰
高洛峰原創
2016-10-13 14:13:401486瀏覽

為什麼計算寬度
計算網頁像素寬度是為了CSS網頁佈局整齊與相容。常見的我們佈局左右結構網頁或使用padding、margin佈局的時候將計算整頁寬度,如果不計算無論是寬度過大過小就會出現錯位問題。

怎麼計算CSS寬度
例一:我們計算一個左右結構的佈局樣式。
假如總寬度為400px,那麼左右加起來就應當小於400px,那我們可能左邊為300px,右邊為100px
正確代碼:

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>左右结构宽度计算www.webjx.com</title>
<style type="text/css">
.webjxcom{width:400px;}
.zuo{ float:left; width:300px; background:#CCC;}
.you{ float:right; width:100px; background:#999}
</style>
</head>
<body>
<div class="webjxcom">
<div class="zuo">左边300px</div>
<div class="you">右边100px</div>
</div>
</body>
</html>

以上為正確的左右結構總寬度剛好等於400px

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>左右结构宽度计算www.webjx.com</title>
<style type="text/css">
.webjxcom{width:400px;}
.zuo{ float:left; width:300px; background:#CCC;}
.you{ float:right; width:120px; background:#999}
</style>
</head>
<body>
<div class="webjxcom">
<div class="zuo">左边300px</div>
<div class="you">右边100px</div>
</div>
</body>
</html>

以上為正確的左右結構總寬度
我們在總寬度不變情況下,左邊為300px,而右邊為120px那總寬度超過了20px,我們看看會出現什麼問題,DIV+CSS代碼如下:

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>左右结构宽度计算www.webjx.com</title>
<style type="text/css">
.webjxcom{width:400px;}
.zuo{ float:left; width:298px; border:1px solid #F00; background:#CCC;}
.you{ float:right; width:98px; background:#999; border:1px solid #F00;}
</style>
</head>
<body>
<div class="webjxcom">
<div class="zuo">左边300px</div>
<div class="you">右边100px</div>
</div>
</body>
</html>

我們根據上圖可看出因為總寬度大約了20px,所以導致了左右結構不能平齊,就出現了右邊往下掉。
這樣就出現了錯位的兼容問題,一般在實際中因為我們計算的疏忽,一般相差小的時候是1px-2px,那樣就不會被我們發現,所以排除錯位兼容可以從寬度計算入手。

例二:左右結構中有1px邊框實例
一般左右結構中有1px邊框,然後再加上有些邊框這時我們設定左右結構時候就需要將此邊框寬度與左右結構寬度計算在一起。
正確範例:
CSS與html程式碼如下:

rrreee

因左右結構都有1px的寬度這個時候各需要減去左右2像素的邊框寬度,所以左邊最後是298px,右邊為98px的寬度

如果不減去邊框將會造成效果:

DIV+CSS設定百分比寬度計算
有時候我們也需要使用百分比來計算寬度,通常情況也是總的百分比寬度,不能超過100%

CSS寬度計算時候注意總結:
無論是左右結構、多列的佈局或單獨一個DIV寬度的佈局設定都需要注意寬度的把握與計算,特別是使用了padding、margin、邊框等CSS屬性,這個時候我們都需要將它們設定的佔用寬度計算入內,牢牢掌握同排各寬度總和小於或等於總寬度,若大於總寬度將會出現錯置的相容問題。所以一般錯位時我們就可以從計算寬度入手,當然錯位還有很多原因這裡也是解決錯位相容問題的方法之一。


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn