WordPress主题开发教程二十:宽度和布局(wordpress主题制作教程)

爱旅游的晓婷 次浏览

摘要:这篇将介绍如何设置每个位置 DIV 的宽度和布局排版,并且也会展示如何让主题显示正确,并同时在 Firefox 和 IE 下兼容,显示一致。在我

Firefox

浏览器,IE 浏览器,index.php和style.css这两个文件第1步:设置页面总体宽度现在我们首先要确定的是主题的总体宽度我们使用 750px;主题的大小取决于博客绝大多数访问者的屏幕分辨率需要避免的是使用过大宽度的 的主题,如果博客的读者都大多数使用 800px × 600px 屏幕,这样的话,如果是使用 900px 款的主题将会有 100多个像素超出他们的屏幕,显然这是对用户很不友好的。

不管怎样,我们怎么样把主题的总体宽度设置为 750px 呢?我们需要把现在主题中的所有的东西(header,container,sidebar 和 footer)放入一个 750px 的 DIV 标签中。

在 之后增加:

在 之前增加:
在 style.css 文件中输入以下代码:#wrapper{margin: 0 auto 0 auto;

width: 750px;text-align: left;}在 CSS,# 号是通过 id 来定位页面中的元素,而点号是通过 class 来定位页面中的元素,如果你的代码是

,那么就应该用 .wrapper 来替代#wrapper 去定位 wrapper 这个 DIV 标签同时保存 index.php 和 style.css 文件刷新 Firefox 和 IE 浏览器(按 F5)查看所做的改动。

详细解释:margin: 0 auto 0 auto; 意思是(注意顺序):0上页边空白,自动右页面空白,0下页边空白和自动左页面空白从现在开始,记得设置左右页边空白为自动将使得居中对齐width: 750px;。

显而易见是 750 像素text-align: left; 是让 wrapper DIV 我们的文本向左对齐因为我们等下要要将 body{ text-align: left;} 改成 text-align: center;。

第2步:自动页面居中把 body{} 中的 text-align: left; 改成 text-align: center;为什么?(我假设你使用的是 Firefox 和 Internet Explorer 6)。

你的布局可能看起来是正确的,但对于使用早前版本的 IE 用户可能不正确还记得设置左边和右边的页边空白为自动数居中吗?但是这并不是对所有的 IE 都适用,所以 body{ text-align: center; }

是让 wrapper DIV 居中在旧版本 IE 的一种解决方案(随便说一下,再说 Firefox 和 IE 中文本大小是不同的,我们稍后解决)第3步:设置 header 宽度和布局让 Header 浮到左边并且设置它的宽度为 750px:

#header{float: left;width: 750px;}第4步:设置 Container 宽度和布局让 Container 浮到左边并且宽度为 500px:#container{float: left;

width: 500px;}第5步:设置 Sidebar 宽度和布局让 Sidebar 浮到左边,宽度为240px,并且给它灰色的背景:.sidebar{float: left;width: 240px;

background: #eeeeee;}#ffffff 是白色而background: #eeeeee; 是非常浅的灰色我们给侧边栏增加一个背景颜色只是去查看当增加剩下的 10 像素之后的不同之处第6步:设置 Footer 的宽度和布局

让 Footer 浮到左边,左右两边都没有东西,并且宽度为:750px:#footer{clear: both;float: left;width: 750px;}Header 和 Footer 的样式有什么区别呢?答案是

footer{} 中有 clear: both;它在那儿使得 Footer 不能和它上面的东西(如 Sidebar 或者 Container)连接起来保存并刷新浏览器第7步:给侧边栏增加其余的 10 像素。

给侧边栏增加其余的 10 像素的页边空白现在侧边栏的 CSS 应该是:.sidebar{float: left;width: 240px;background: #eeeeee;margin: 0 0 0 10px;。

}保存并刷新浏览器去查看 10 像素的空白增加到侧边栏的左边了margin: 0 0 0 10px; 具体的意思是:上边空白为0,右边空白为0,底部空白为0,左边空白为10像素当大小为0的时候,px 单位不是必需的。

第8步(额外的步骤):修正 IE 的双倍页边距 bugInternet Explorer 有个双倍页边距的 bug,这样在 IE 下,我们的页面距就是 20像素,20像素的页边距可能会破坏布局并把侧边栏挤到页面的底部,因为一个20像素的页边距使得 Container 和 Sidebar 的宽度之和为 760px 而不是 750px。

为了解决这个问题,增加 display: inline; 到侧边栏现在你的侧边栏应该是:.sidebar{float: left;width: 240px;background: #eeeeee;margin: 0 0 0 10px;。

display: inline;}这里是现在的 index 和 style 文件的内容。

随机内容