结构化面试:阻碍你学习CSS的因素 思维的转变 HTML结构化



  你正在学习CSS布局吗?是不是还不能完全掌握纯CSS布局?通常有两种情况阻碍你学习:
  第种可能是你还没有理解CSS处理页面原理在你考虑你页面整体表现效果前你应当先考虑内容语义和结构然后再针对语义、结构添加CSS这篇文章将告诉你应该怎样把HTML结构化
  另种原因是你对那些非常熟悉表现层属性(例如:cellpadding,、hspace、align=\"left\"等等)束手无策不知道该转换成对应什么CSS语句当你解决了第种问题知道了如何结构化你HTML我再给出个列表详细列出原来表现属性用什么CSS来代替

结构化HTML

  我们在刚学习网页制作时总是先考虑如何设计考虑那些图片、字体、颜色、以及布局方案然后我们用Photoshop或者Fireworks画出来、切割成小图最后再通过编辑HTML将所有设计还原表现在页面上
  如果你希望你HTML页面用CSS布局(是CSS-friendly)你需要回头重来先不考虑“外观”要先研究你页面内容语义和结构
  外观并不是最重要个结构良好HTML页面可以以任何外观表现出来CSSZenGarden是个典型例子CSSZenGarden帮助我们最终认识到CSS强大力量
  HTML不仅仅只在电脑屏幕上阅读你用photoshop精心设计画面可能不能显示在PDA、移动电话和屏幕阅读机上但是个结构良好HTML页面可以通过CSS区别定义显示在任何地方任何网络设备上

开始研究

  首先要学习什么是\"结构\"些作家也称的为\"语义\"这个术语意思是你需要分析你内容块以及每块内容服务然后再根据这些内容目建立起相应HTML结构
  如果你坐下来仔细分析和规划你页面结构你可能得到类似这样几块:

\" style=\"margin:0px 2px -3px 0px\" alt=\"div css xhtml xml Example Source Code\"/> Example Source Code [www.52css.com]
    标志和站点名称
    主页面内容
    站点导航(主菜单)
    子菜单
    搜索框
    功能区(例如购物车、收银台)
    页脚(版权和有关法律声明)


  我们通常采用DIV元素来将这些结构定义出来类似这样:

\" style=\"margin:0px 2px -3px 0px\" alt=\"div css xhtml xml Example Source Code\"/> Example Source Code [www.52css.com]
<divid=\"header\"></div>
<divid=\"content\"></div>
<divid=\"globalnav\"></div>
<divid=\"subnav\"></div>
<divid=\"search\"></div>
<divid=\"shop\"></div>
<divid=\"footer\"></div>


  这不是布局是结构这是个对内容块语义介绍说明当你理解了你结构就可以加对应ID在DIV上DIV容器中可以包含任何内容块也可以嵌套另个DIV内容块可以包含任意HTML元素---标题、段落、图片、表格、列表等等
  根据上面讲述你已经知道如何结构化HTML现在你可以进行布局和样式定义了个内容块都可以放在页面上任何地方再指定这个块颜色、字体、边框、背景以及对齐属性等等

使用选择器是件美妙

  id名称是控制某内容块手段,通过给这个内容块套上DIV并加上唯id,你就可以用CSS选择器来精确定义每个页面元素外观表现,包括标题、列表、图片、链接或者段落等等例如你为#header写个CSS规则就可以完全区别于#content里图片规则
  另外个例子是:你可以通过区别规则来定义区别内容块里链接样式类似这样:#globalnava:link或者#subnava:link或者#contenta:link你也可以定义区别内容块中相同元素样式不例如通过#contentp和#footerp分别定义#content和#footer中p样式从结构上讲页面是由图片、链接、列表、段落等组成这些元素本身并不会对显示在什么网络设备中(PDA还是手机或者网络电视)有影响它们可以被定义为任何表现外观
  个仔细结构化HTML页面非常简单个元素都被用于结构目当你想缩进个段落不需要使用blockquote标签只要使用p标签并对p加个CSSmargin规则就可以实现缩进目p是结构化标签margin是表现属性前者属于HTML后者属于CSS(这就是结构于表现相分离.)
  良好结构HTML页面内几乎没有表现属性标签代码非常干净简洁例如原先代码<tablewidth=\"80%\"cellpadding=\"3\"border=\"2\"align=\"left\">现在可以只在HTML中写<table>所有控制表现东西都写到CSS中去在结构化HTML中table就是表格而不是其他什么(比如被用来布局和定位)

亲自实战下结构化

  上面说只是最基本结构实际应用中你可以根据需要来调整内容块常常会出现DIV嵌套情况你会看到\"container\"层中又有其它层结构类似这样:

\" style=\"margin:0px 2px -3px 0px\" alt=\"div css xhtml xml Example Source Code\"/> Example Source Code [www.52css.com]


<divid=\"navcontainer\">
<divid=\"globalnav\">
<ul>alist</ul>
</div>
<divid=\"subnav\">
<ul>anotherlist</ul>
</div>
</div>


  嵌套div元素允许你定义更多CSS规则来控制表现例如:你可以给#navcontainer个规则让列表居右再给#globalnav个规则让列表居左而给#subnavlist另个完全区别表现

用CSS替换传统思路方法
  下面列表将帮助你用CSS替换传统思路方法:

\" style=\"margin:0px 2px -3px 0px\" alt=\"div css xhtml xml Source Code to Run\"> Source Code to Run [www.52css.com]