你正在学习CSS布局吗?是不是还不能完全掌握纯CSS布局?通常有两种情况阻碍你
![](/icons/17839de.gif)
学习:
第
![](/icons/17839yi.gif)
种可能是你还没有理解CSS处理页面
![](/icons/17839de.gif)
原理
![](/icons/17839dou2.gif)
在你考虑你
![](/icons/17839de.gif)
页面整体表现效果前
![](/icons/17839dou.gif)
你应当先考虑内容
![](/icons/17839de.gif)
语义和结构
![](/icons/17839dou.gif)
然后再针对语义、结构添加CSS
![](/icons/17839dou2.gif)
这篇文章将告诉你应该怎样把HTML结构化
![](/icons/17839dou2.gif)
另
![](/icons/17839yi.gif)
种原因是你对那些非常熟悉
![](/icons/17839de.gif)
表现层属性(例如:cellpadding,、hspace、align=\"left\"等等)束手无策
![](/icons/17839dou.gif)
不知道该转换成对应
![](/icons/17839de.gif)
什么CSS语句
![](/icons/17839dou2.gif)
当你解决了第
![](/icons/17839yi.gif)
种问题
![](/icons/17839dou.gif)
知道了如何结构化你
![](/icons/17839de.gif)
HTML
![](/icons/17839dou.gif)
我再给出
![](/icons/17839yi.gif)
个列表
![](/icons/17839dou.gif)
详细列出原来
![](/icons/17839de.gif)
表现属性用什么CSS来代替
![](/icons/17839dou2.gif)
结构化HTML
我们在刚学习网页制作时
![](/icons/17839dou.gif)
总是先考虑如何设计
![](/icons/17839dou.gif)
考虑那些图片、字体、颜色、以及布局方案
![](/icons/17839dou2.gif)
然后我们用Photoshop或者Fireworks画出来、切割成小图
![](/icons/17839dou2.gif)
最后再通过编辑HTML将所有设计还原表现在页面上
![](/icons/17839dou2.gif)
如果你希望你
![](/icons/17839de.gif)
HTML页面用CSS布局(是CSS-friendly
![](/icons/17839de.gif)
)
![](/icons/17839dou.gif)
你需要回头重来
![](/icons/17839dou.gif)
先不考虑“外观”
![](/icons/17839dou.gif)
要先研究你
![](/icons/17839de.gif)
页面内容
![](/icons/17839de.gif)
语义和结构
![](/icons/17839dou2.gif)
外观并不是最重要
![](/icons/17839de.gif)
![](/icons/17839dou2.gif)
![](/icons/17839yi.gif)
个结构良好
![](/icons/17839de.gif)
HTML页面可以以任何外观表现出来
![](/icons/17839dou.gif)
CSSZenGarden是
![](/icons/17839yi.gif)
个典型
![](/icons/17839de.gif)
例子
![](/icons/17839dou2.gif)
CSSZenGarden帮助我们最终认识到CSS
![](/icons/17839de.gif)
强大力量
![](/icons/17839dou2.gif)
HTML不仅仅只在电脑屏幕上阅读
![](/icons/17839dou2.gif)
你用photoshop精心设计
![](/icons/17839de.gif)
画面可能不能显示在PDA、移动电话和屏幕阅读机上
![](/icons/17839dou2.gif)
但是
![](/icons/17839yi.gif)
个结构良好
![](/icons/17839de.gif)
HTML页面可以通过CSS
![](/icons/17839de.gif)
区别定义
![](/icons/17839dou.gif)
显示在任何地方
![](/icons/17839dou.gif)
任何网络设备上
![](/icons/17839dou2.gif)
开始研究
首先要学习什么是\"结构\"
![](/icons/17839dou.gif)
![](/icons/17839yi.gif)
些作家也称的为\"语义\"
![](/icons/17839dou2.gif)
这个术语
![](/icons/17839de.gif)
意思是你需要分析你
![](/icons/17839de.gif)
内容块
![](/icons/17839dou.gif)
以及每块内容服务
![](/icons/17839de.gif)
目
![](/icons/17839de.gif)
![](/icons/17839dou.gif)
然后再根据这些内容目
![](/icons/17839de.gif)
建立起相应
![](/icons/17839de.gif)
HTML结构
![](/icons/17839dou2.gif)
如果你坐下来仔细分析和规划你
![](/icons/17839de.gif)
页面结构
![](/icons/17839dou.gif)
你可能得到类似这样
![](/icons/17839de.gif)
几块:
标志和站点名称
主页面内容
站点导航(主菜单)
子菜单
搜索框
功能区(例如购物车、收银台)
页脚(版权和有关法律声明)
我们通常采用DIV元素来将这些结构定义出来
![](/icons/17839dou.gif)
类似这样:
<divid=\"header\"></div>
<divid=\"content\"></div>
<divid=\"globalnav\"></div>
<divid=\"subnav\"></div>
<divid=\"search\"></div>
<divid=\"shop\"></div>
<divid=\"footer\"></div>
这不是布局
![](/icons/17839dou.gif)
是结构
![](/icons/17839dou2.gif)
这是
![](/icons/17839yi.gif)
个对内容块
![](/icons/17839de.gif)
语义介绍说明
![](/icons/17839dou2.gif)
当你理解了你
![](/icons/17839de.gif)
结构
![](/icons/17839dou.gif)
就可以加对应
![](/icons/17839de.gif)
ID在DIV上
![](/icons/17839dou2.gif)
DIV容器中可以包含任何内容块
![](/icons/17839dou.gif)
也可以嵌套另
![](/icons/17839yi.gif)
个DIV
![](/icons/17839dou2.gif)
内容块可以包含任意
![](/icons/17839de.gif)
HTML元素---标题、段落、图片、表格、列表等等
![](/icons/17839dou2.gif)
根据上面讲述
![](/icons/17839de.gif)
![](/icons/17839dou.gif)
你已经知道如何结构化HTML
![](/icons/17839dou.gif)
现在你可以进行布局和样式定义了
![](/icons/17839dou2.gif)
每
![](/icons/17839yi.gif)
个内容块都可以放在页面上任何地方
![](/icons/17839dou.gif)
再指定这个块
![](/icons/17839de.gif)
颜色、字体、边框、背景以及对齐属性等等
![](/icons/17839dou2.gif)
使用选择器是件美妙
![](/icons/17839de.gif)
事
id
![](/icons/17839de.gif)
名称是控制某
![](/icons/17839yi.gif)
内容块
![](/icons/17839de.gif)
手段,通过给这个内容块套上DIV并加上唯
![](/icons/17839yi.gif)
![](/icons/17839de.gif)
id,你就可以用CSS选择器来精确定义每
![](/icons/17839yi.gif)
个页面元素
![](/icons/17839de.gif)
外观表现,包括标题、列表、图片、链接或者段落等等
![](/icons/17839dou2.gif)
例如你为#header写
![](/icons/17839yi.gif)
个CSS规则
![](/icons/17839dou.gif)
就可以完全区别于#content里
![](/icons/17839de.gif)
图片规则
![](/icons/17839dou2.gif)
另外
![](/icons/17839yi.gif)
个例子是:你可以通过区别规则来定义区别内容块里
![](/icons/17839de.gif)
链接样式
![](/icons/17839dou2.gif)
类似这样:#globalnava:link或者#subnava:link或者#contenta:link
![](/icons/17839dou2.gif)
你也可以定义区别内容块中相同元素
![](/icons/17839de.gif)
样式不
![](/icons/17839yi.gif)
样
![](/icons/17839dou2.gif)
例如
![](/icons/17839dou.gif)
通过#contentp和#footerp分别定义#content和#footer中p
![](/icons/17839de.gif)
样式
![](/icons/17839dou2.gif)
从结构上讲
![](/icons/17839dou.gif)
你
![](/icons/17839de.gif)
页面是由图片、链接、列表、段落等组成
![](/icons/17839de.gif)
![](/icons/17839dou.gif)
这些元素本身并不会对显示在什么网络设备中(PDA还是手机或者网络电视)有影响
![](/icons/17839dou.gif)
它们可以被定义为任何
![](/icons/17839de.gif)
表现外观
![](/icons/17839yi.gif)
个仔细结构化
![](/icons/17839de.gif)
HTML页面非常简单
![](/icons/17839dou.gif)
每
![](/icons/17839yi.gif)
个元素都被用于结构目
![](/icons/17839de.gif)
![](/icons/17839dou2.gif)
当你想缩进
![](/icons/17839yi.gif)
个段落
![](/icons/17839dou.gif)
不需要使用blockquote标签
![](/icons/17839dou.gif)
只要使用p标签
![](/icons/17839dou.gif)
并对p加
![](/icons/17839yi.gif)
个CSS
![](/icons/17839de.gif)
margin规则就可以实现缩进目
![](/icons/17839de.gif)
![](/icons/17839dou2.gif)
p是结构化标签
![](/icons/17839dou.gif)
margin是表现属性
![](/icons/17839dou.gif)
前者属于HTML
![](/icons/17839dou.gif)
后者属于CSS
![](/icons/17839dou2.gif)
(这就是结构于表现
![](/icons/17839de.gif)
相分离.)
良好结构
![](/icons/17839de.gif)
HTML页面内几乎没有表现属性
![](/icons/17839de.gif)
标签
![](/icons/17839dou2.gif)
代码非常干净简洁
![](/icons/17839dou2.gif)
例如
![](/icons/17839dou.gif)
原先
![](/icons/17839de.gif)
代码<tablewidth=\"80%\"cellpadding=\"3\"border=\"2\"align=\"left\">
![](/icons/17839dou.gif)
现在可以只在HTML中写<table>
![](/icons/17839dou.gif)
所有控制表现
![](/icons/17839de.gif)
东西都写到CSS中去
![](/icons/17839dou.gif)
在结构化
![](/icons/17839de.gif)
HTML中
![](/icons/17839dou.gif)
table就是表格
![](/icons/17839dou.gif)
而不是其他什么(比如被用来布局和定位)
![](/icons/17839dou2.gif)
亲自实战
![](/icons/17839yi.gif)
下结构化
上面说
![](/icons/17839de.gif)
只是最基本
![](/icons/17839de.gif)
结构
![](/icons/17839dou.gif)
实际应用中
![](/icons/17839dou.gif)
你可以根据需要来调整内容块
![](/icons/17839dou2.gif)
常常会出现DIV嵌套
![](/icons/17839de.gif)
情况
![](/icons/17839dou.gif)
你会看到\"container\"层中又有其它层
![](/icons/17839dou.gif)
结构类似这样:
<divid=\"navcontainer\">
<divid=\"globalnav\">
<ul>alist</ul>
</div>
<divid=\"subnav\">
<ul>anotherlist</ul>
</div>
</div>
嵌套
![](/icons/17839de.gif)
div元素允许你定义更多
![](/icons/17839de.gif)
CSS规则来控制表现
![](/icons/17839dou.gif)
例如:你可以给#navcontainer
![](/icons/17839yi.gif)
个规则让列表居右
![](/icons/17839dou.gif)
再给#globalnav
![](/icons/17839yi.gif)
个规则让列表居左
![](/icons/17839dou.gif)
而给#subnav
![](/icons/17839de.gif)
list另
![](/icons/17839yi.gif)
个完全区别
![](/icons/17839de.gif)
表现
![](/icons/17839dou2.gif)
用CSS替换传统思路方法
下面
![](/icons/17839de.gif)
列表将帮助你用CSS替换传统思路方法:
HTML属性以及相对应
![](/icons/17839de.gif)
CSS思路方法
HTML属性
CSS思路方法介绍说明
align=\"left\"
align=\"right\"float:left;
float:right;使用CSS可以浮动任何元素:图片、段落、div、标题、表格、列表等等
当你使用float属性
![](/icons/17839dou.gif)
必须给这个浮动元素定义
![](/icons/17839yi.gif)
个宽度
![](/icons/17839dou2.gif)
marginwidth=\"0\"leftmargin=\"0\"marginheight=\"0\"topmargin=\"0\"margin:0;使用CSS,margin可以设置在任何元素上,不仅仅是body元素.更重要
![](/icons/17839de.gif)
![](/icons/17839dou.gif)
你可以分别指定元素
![](/icons/17839de.gif)
top,right,bottom和left
![](/icons/17839de.gif)
margin值
vlink=\"#333399\"alink=\"#000000\"link=\"#3333FF\"a:link#3ff;
a:visited:#339;
a:hover:#999;
a:active:#00f;
在HTML中
![](/icons/17839dou.gif)
链接
![](/icons/17839de.gif)
颜色作为body
![](/icons/17839de.gif)
![](/icons/17839yi.gif)
个属性值定义
![](/icons/17839dou2.gif)
整个页面
![](/icons/17839de.gif)
链接风格都
![](/icons/17839yi.gif)
样
![](/icons/17839dou2.gif)
使用CSS
![](/icons/17839de.gif)
选择器
![](/icons/17839dou.gif)
页面区别部分
![](/icons/17839de.gif)
链接样式可以不
![](/icons/17839yi.gif)
样
![](/icons/17839dou2.gif)
bgcolor=\"#FFFFFF\"background-color:#fff;在CSS中
![](/icons/17839dou.gif)
任何元素都可以定义背景颜色
![](/icons/17839dou.gif)
不仅仅局限于body和table元素
![](/icons/17839dou2.gif)
bordercolor=\"#FFFFFF\"border-color:#fff;任何元素都可以设置边框(boeder)
![](/icons/17839dou.gif)
你可以分别定义top,right,bottom和left
border=\"3\" cellspacing=\"3\"border-width:3px;用CSS
![](/icons/17839dou.gif)
你可以定义table
![](/icons/17839de.gif)
边框为统
![](/icons/17839yi.gif)
样式
![](/icons/17839dou.gif)
也可以分别定义top,right,bottomandleft边框
![](/icons/17839de.gif)
颜色、尺寸和样式
![](/icons/17839dou2.gif)
你可以使用table,tdorth这些选择器.
如果你需要设置无边框效果
![](/icons/17839dou.gif)
可以使用CSS定义:border-collapse:collapse;
<brclear=\"left\">
<brclear=\"right\">
<brclear=\"all\">
clear:left;
clear:right;
clear:both;
许多2列或者3列布局都使用float属性来定位
![](/icons/17839dou2.gif)
如果你在浮动层中定义了背景颜色或者背景图片
![](/icons/17839dou.gif)
你可以使用clear属性.
cellpadding=\"3\"
vspace=\"3\"
hspace=\"3\"padding:3px;用CSS
![](/icons/17839dou.gif)
任何元素都可以设定padding属性
![](/icons/17839dou.gif)
同样
![](/icons/17839dou.gif)
padding可以分别设置top,right,bottomandleft
![](/icons/17839dou2.gif)
padding是透明
![](/icons/17839de.gif)
![](/icons/17839dou2.gif)
align=\"center\"text-align:center;
margin-right:auto;margin-left:auto;
Text-align只适用于文本.
象div
![](/icons/17839dou.gif)
p这样
![](/icons/17839de.gif)
块级可以通过margin-right:auto;和margin-left:auto;来水平居中
![](/icons/17839yi.gif)
些令人遗憾
![](/icons/17839de.gif)
窍门技巧和工作环境
由于浏览器对CSS支持
![](/icons/17839de.gif)
不完善
![](/icons/17839dou.gif)
我们有时候不得不采取
![](/icons/17839yi.gif)
些窍门技巧(hacks)或建立
![](/icons/17839yi.gif)
种环境(Workarounds)来让CSS实现传统思路方法同样
![](/icons/17839de.gif)
效果
![](/icons/17839dou2.gif)
例如块级元素有时侯需要使用水平居中
![](/icons/17839de.gif)
窍门技巧
![](/icons/17839dou.gif)
盒模型bug
![](/icons/17839de.gif)
窍门技巧等等
![](/icons/17839dou2.gif)
所有这些窍门技巧都在MollyHolzschlag
![](/icons/17839de.gif)
文章
![](/icons/17839smhl.gif)
IntegratedWebDesign:StrategiesforLong-TermCSSHackManagement
![](/icons/17839smhr.gif)
中有详细介绍说明
![](/icons/17839dou2.gif)
另外
![](/icons/17839yi.gif)
个有关CSS窍门技巧
![](/icons/17839de.gif)
资源站点是BigJohn和HollyBergevin
![](/icons/17839de.gif)
“PositionisEverything”
![](/icons/17839dou2.gif)
理解浮动行为
EricMeyer
![](/icons/17839de.gif)
![](/icons/17839smhl.gif)
ContainingFloats
![](/icons/17839smhr.gif)
将帮助你掌握如何使用float属性布局
![](/icons/17839dou2.gif)
float元素有时候需要清除(clear)
![](/icons/17839dou.gif)
阅读
![](/icons/17839smhl.gif)
HowToClearFloatsWithoutStructuralMarkup
![](/icons/17839smhr.gif)
将非常有帮助
![](/icons/17839dou2.gif)
更多帮助
已有
![](/icons/17839de.gif)
![](/icons/17839smhl.gif)
CSSDiscussion
![](/icons/17839smhr.gif)
列表是很好
![](/icons/17839de.gif)
资源
![](/icons/17839dou.gif)
它收集了
![](/icons/17839yi.gif)
个WiKiA讨论组
![](/icons/17839de.gif)
信息
![](/icons/17839dou.gif)
其中包括CSS布局整理总结(css-discuss.incutio.com/?page=CssLayouts)
![](/icons/17839dou.gif)
CSS窍门技巧整理总结(css-discuss.incutio.com/?page=CssHack)以及更多
Tags:
延伸阅读
最新评论