DIV CSS网页布局:HTML结构化 DIV CSS网页布局入门指南



  你正在学习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结构
  如果你坐下来仔细分析和规划你页面结构你可能得到类似这样几块:
  标志和站点名称
  主页面内容
  站点导航(主菜单)
  子菜单
  搜索框
  功能区(例如购物车、收银台)
  页脚(版权和有关法律声明)

  我们通常采用DIV元素来将这些结构定义出来类似这样:
  <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\"层中又有其它层结构类似这样:
  <divid=\"navcontainer\">
  <divid=\"globalnav\">
  <ul>alist</ul>
  </div>
  <divid=\"subnav\">
  <ul>anotherlist</ul>
  </div>
  </div>
  嵌套div元素允许你定义更多CSS规则来控制表现例如:你可以给#navcontainer个规则让列表居右再给#globalnav个规则让列表居左而给#subnavlist另个完全区别表现

  用CSS替换传统思路方法
  下面列表将帮助你用CSS替换传统思路方法:
  HTML属性以及相对应CSS思路方法
  HTML属性

  CSS思路方法介绍说明
  align=\"left\"
  align=\"right\"float:left;
  float:right;使用CSS可以浮动任何元素:图片、段落、div、标题、表格、列表等等

  当你使用float属性必须给这个浮动元素定义个宽度
  marginwidth=\"0\"leftmargin=\"0\"marginheight=\"0\"topmargin=\"0\"margin:0;使用CSS,margin可以设置在任何元素上,不仅仅是body元素.更重要你可以分别指定元素top,right,bottom和leftmargin值


  vlink=\"#333399\"alink=\"#000000\"link=\"#3333FF\"a:link#3ff;
  a:visited:#339;
  a:hover:#999;
  a:active:#00f;
  在HTML中链接颜色作为body个属性值定义整个页面链接风格都使用CSS选择器页面区别部分链接样式可以不
  bgcolor=\"#FFFFFF\"background-color:#fff;在CSS中任何元素都可以定义背景颜色不仅仅局限于body和table元素
  bordercolor=\"#FFFFFF\"border-color:#fff;任何元素都可以设置边框(boeder)你可以分别定义top,right,bottom和left
  border=\"3\" cellspacing=\"3\"border-width:3px;用CSS你可以定义table边框为统样式也可以分别定义top,right,bottomandleft边框颜色、尺寸和样式
  你可以使用table,tdorth这些选择器.
  如果你需要设置无边框效果可以使用CSS定义:border-collapse:collapse;
  <brclear=\"left\">
  <brclear=\"right\">
  <brclear=\"all\">
  clear:left;
  clear:right;
  clear:both;
  许多2列或者3列布局都使用float属性来定位如果你在浮动层中定义了背景颜色或者背景图片你可以使用clear属性.
  cellpadding=\"3\"
  vspace=\"3\"
  hspace=\"3\"padding:3px;用CSS任何元素都可以设定padding属性同样padding可以分别设置top,right,bottomandleftpadding是透明
  align=\"center\"text-align:center;
  margin-right:auto;margin-left:auto;
  Text-align只适用于文本.
  象divp这样块级可以通过margin-right:auto;和margin-left:auto;来水平居中

  些令人遗憾窍门技巧和工作环境
  由于浏览器对CSS支持不完善我们有时候不得不采取些窍门技巧(hacks)或建立种环境(Workarounds)来让CSS实现传统思路方法同样效果例如块级元素有时侯需要使用水平居中窍门技巧盒模型bug窍门技巧等等所有这些窍门技巧都在MollyHolzschlag文章IntegratedWebDesign:StrategiesforLong-TermCSSHackManagement中有详细介绍说明
  另外个有关CSS窍门技巧资源站点是BigJohn和HollyBergevin“PositionisEverything”

  理解浮动行为
  EricMeyerContainingFloats将帮助你掌握如何使用float属性布局float元素有时候需要清除(clear)阅读HowToClearFloatsWithoutStructuralMarkup将非常有帮助

  更多帮助
  已有CSSDiscussion列表是很好资源它收集了个WiKiA讨论组信息其中包括CSS布局整理总结(css-discuss.incutio.com/?page=CssLayouts)CSS窍门技巧整理总结(css-discuss.incutio.com/?page=CssHack)以及更多
Tags: 

延伸阅读

最新评论

发表评论