`
wjlgryx
  • 浏览: 308615 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

HTML5和CSS3

阅读更多

跟<div>说再见,欢迎语义化标签
  曾经,设计师们经常会跟频繁使用基于table的没有任何语义的布局。不过最终还是要感谢像Jeffrey Zeldman和Eric Meyer这样的思想革新者,聪明的设计师们慢慢的接受了相对更语义化的<div>布局替代了table布局,并且开始调用外部样式表。但不幸的是,复杂的网页设计需要大量不同的标签结构代码,我们把它叫做“<div>-soup” 综合症。也许你很熟悉下面的代码:

<div id="news">
   <div class="section">
      <div class="article">
         <div class="header">
            <h1>Div Soup Demonstration</h1>
            <p>Posted on July 11th, 2009</p>
         </div>
         <div class="content">
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
         </div>
         <div class="footer">
            <p>Tags: HMTL, code, demo</p>
         </div>
      </div>
      <div class="aside">
         <div class="header">
            <h1>Tangential Information</h1>
         </div>
         <div class="content">
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
         </div>
         <div class="footer">
            <p>Tags: HMTL, code, demo</p>
         </div>
      </div>
   </div>
</div>
  尽管这有些勉强,但上面这个实例还是可以说明使用HTML4对一个复杂的设计进行代码化后依然过于臃肿(其实xHTML1.1也不过如此)。不过值得激动的是,HTML5解决“<div>-soup” 综合症并带给我们一套新的结构化元素。这些新的HTML5元素富有更细致的语义从而代替了那些毫无语义的<div>标签,并同时为CSS的调用提供了”自然”的CSS钩子。下面是HTML5的解决方案实例:

<section>
   <section>
      <article>
         <header>
            <h1>Div Soup Demonstration</h1>
            <p>Posted on July 11th, 2009</p>
         </header>
         <section>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
         </section>
         <footer>
            <p>Tags: HMTL, code, demo</p>
         </footer>
      </article>
      <aside>
         <header>
            <h1>Tangential Information</h1>
         </header>
         <section>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
            <p>Lorem ipsum text blah blah blah.</p>
         </section>
         <footer>
            <p>Tags: HMTL, code, demo</p>
         </footer>
      </aside>
   </section>
</section>
  正如我们所见,HTML5可以让我们用很多更语义化的结构化代码标签代替那些大量的无意义的<div>标签。这种语义化的特性不仅提升了我们网页的质量和语义,并且大量减少了曾经代码中用于CSS必须调用的class和id属性。事实上,CSS3也是可以然通过我们忽略掉所有class和id的。
跟class属性说再见,欢迎整洁的标签
  结合了富有新的语义化标记的HTML5,CSS3为web设计师们的网页提供了神一般的力量。有了HTML5的能量,我们将得到更多的对文档代码的控制权,有了CSS3的能量,我们的控制权将趋于无穷大!
  即使没有那些高级的CSS选择器,我们仍然可以通过强大的HTML5条调用不同的容器而不劳驾class和id这类属性。像以往的DIV布局,我们在css中可能要这样调用:
div#news    {}
div.section {}
div.article {}
div.header  {}
div.content {}
div.footer  {}
div.aside   {}
我们再来看看基于HTML5的实例:
section {}
article {}
header  {}
footer  {}
aside   {}
  这是个进步,但仍有一些问题需要解决。在<div>实例中,我们需要通过class或id属性来调用页面中的元素。这种逻辑将允许我们将样式应用到文档中的任何一个元素上,无论是整体还是个体。例如在<div>实例中,.section 和 .content元素很容易定位。但是在HTML5实例中,实际文档中会有很多个section元素。其实我们可以添加一些特定的属性选择器来调用那些不同的section元素,不过谢天谢地,我没现在可以用少量的高级CSS选择器来定位不同的section元素。
不使用class和id定位HTML-5元素
  下面让我们来看看如何在不使用class和id的情况下定位HTML5页面元素的一个实例,我们可以使用三种CSS选择器来定位和辨别实例中的元素。如下:
后代选择器:[CSS 2.1]: E F
兄弟选择器:[CSS 2.1]: E + F
子元素选择器:[CSS 2.1]: E > F
下面让我们来看看如何不使用class和id而完成对文档中的那些section元素的定位吧:

定位最外层的<section>元素
  考虑到我们的例子并不是一套完整的HTML5代码,所以我们假定在<body>元素下有个<nav>元素与<section>元素是兄弟元素。这样的话,我们就可以向下面代码那样定位最外层的<section>了:

body nav+section {}
定位下一个<section>元素
作为最外层<section>元素下的唯一直属子集元素,这个<section>元素也许可以这样定位:

section>section {}
定位<article>元素
可以定位<article>元素的方法有很多,不过最简单的方法当然就是后代选择器了:

section section article {}
定位<header>、<section>和<footer>元素
这三个元素分别在两个地方都出现过,一是在<article>元素中出现,另一是在<aside>元素中出现。这种差别能让我们轻松定位每个元素。

article header {}
article section {}
article footer {}
或者一起定义:

section section header {}
section section section {}
section section footer {}
  到目前为止,我们已经使用CSS2.1选择器排除掉了所有的class和id。那么我们为什么还需要使用CSS3呢?我很高兴你能这么问…
使用CSS3对HTML5元素进行高级定位
  虽然我们已经使用CSS2.1选择器排除掉了所有的class和id,显然还会有很多更复杂的情况需要CSS3的高级选择器来解决。让我们通过完成一下的实例来了解一下如何在不使用无用的class和id属性的情况下利用CSS3定位页面元素。
使用一个唯一的日志(post)ID定位所有日志
  wordpress提供给我们一种包含了ID的每篇日志的源代码输出。这种信息通常用于导航和/或了解资料的意图,不过CSS3可以利用这些唯一的ID来定义这些日志的样式。当然,你还可以像往常那样为每篇日志添加class=”post”这样的属性,但这就与我们练习的意图相冲突了(再加上它没有一点乐趣所在)。使用”子字符串匹配选择器”,我们就可以像下面这样定位所有日志和它们的不同元素了。

article[id*=post-] {}           /* 定位所有日志 */
article[id*=post-] header h1 {} /* 定位所有日志中的h1标签 */
article[id*=post-] section p {} /* 定位所有日志中的p标签 */
我没仍然可以使用同样的方式定位评论的元素和它们的子元素。

article[id*=comment-] {}           /* 定位所有评论 */
article[id*=comment-] header h1 {} /* 定位所有评论中的h1标签 */
article[id*=comment-] section p {} /* 定位所有评论中的p标签 */
定位一些指定的区域(section)或文章(article)
  有很多博客的日志量和评论量都相当大,HTML 5 会将它们由<section>或<article>元素组成。为了定位哪些指定的<section>或<article>元素,我们就要转而使用强大的“:nth-child”选择器了:
1
2
3
4
5
section:nth-child(1) {} /* 选择第一个 <section> */
article:nth-child(1) {} /* 选择第一个 <article> */

section:nth-child(2) {} /* 选择第二个 <section> */
article:nth-child(2) {} /* 选择第二个 <article> */
同样,我们可以使用“:nth-last-child”选择器定位反序的一些元素。

section:nth-last-child(1) {} /* 选择最后一个 <section> */
article:nth-last-child(1) {} /* 选择最后一个 <article> */

section:nth-last-child(2) {} /* 选择倒数第二个 <section> */
article:nth-last-child(2) {} /* 选择倒数第二个 <article> */
使用更多的方式选择指定元素
  另一种选择HTML5中指定元素(如header、section和footer)的方法就是利用”:only-of-type”选择器的优势。由于这些HTML5元素通常会在很多地方出现不止一次,所以当我们想定位那种在父元素下仅出现过一次的标签时这种方法很方便。例如,我们要选择的是在某
元素中有切仅有的唯一一个
元素,如以下代码:

<section>
   <section></section>
   <section>
      <section>定位这个section元素</section>
   </section>
   <section>
      <section>定位这个section元素</section>
   </section>
   <section>
      <section>但不定位这个section元素</section>
      <section>和这个section元素</section>
   </section>
   <section></section>
</section>
我们可以仅使用以下一行选择器:
1
section>section:only-of-type {}
  再次唠叨,你可以固执的为每个元素添加ID属性,但你会失去代码的可扩展性、维护性和绝对简洁的结构与表现相分离。CSS3的确能让我们可快速更方便的定位几乎所有没有ID和class属性的页面元素。
本文来自http://www.xue5.com/itedu/200908/351341.html

 

分享到:
评论

相关推荐

    CSS权威指南 css彻底设计研究 HTML5和CSS3实战 HTML5与CSS3设计模式

    本文将深入探讨"CSS权威指南"、"css彻底设计研究"、"HTML5和CSS3实战"以及"HTML5与CSS3设计模式"这四个主题中的关键知识点,帮助读者掌握这些领域的核心概念。 首先,"CSS权威指南"是一本经典教程,它全面地介绍了...

    html5和css3

    html5css3 揭秘HTML5和CSS3 HTML5新增和移除的元素 HTML5基本布局 HTML5对表单的支持 HTML5 DOM变化 HTML5的

    HTML5秘籍 HTML5和CSS3实战 HTML5与CSS3设计模式

    HTML5和CSS3是现代网页开发的两大核心技术,它们极大地扩展了互联网应用的功能和视觉表现力。本压缩包包含三本书籍,分别是《HTML5秘籍》、《HTML5和CSS3实战 第2版》以及《HTML5与CSS3设计模式》,这三本书将深入...

    HTML5 CSS3 chm中文参考手册_html5_CSS3_css3.chm_参考手册_

    HTML5和CSS3是现代网页开发的两大核心技术,它们极大地扩展了网页的展现力和交互性。本资源提供了一份详尽的中文参考手册,旨在帮助开发者深入理解和运用这两种技术。 HTML5是HTML(超文本标记语言)的最新版本,它...

    利用HTML5和CSS3实现很酷的3D纸片折叠动画效果

    HTML5和CSS3是现代网页开发的两大核心技术,它们为创建动态、交互性强且视觉效果丰富的网站提供了强大的工具。在本项目中,我们将探讨如何利用HTML5和CSS3实现一个令人印象深刻的3D纸片折叠动画效果。 首先,HTML5...

    《html5和css3实例教程》源代码

    HTML5和CSS3是现代网页开发的两大核心技术,它们极大地扩展了网页的可表现性和功能。这个《HTML5和CSS3实例教程》源代码压缩包提供了丰富的实例,帮助学习者深入理解和掌握这两种语言的运用。 HTML5是超文本标记...

    HTML5与CSS3基础教程 第八版 中文版 高清 PDF

    HTML5和CSS3是现代网页开发的两大核心技术,它们为创建功能丰富、视觉效果出色的网页提供了强大的工具。《HTML5与CSS3基础教程 第八版 中文版》是一本全面介绍这两个技术的书籍,旨在帮助初学者快速入门,并提供给...

    响应式web设计:html5和css3实战(高清无水印)

    全面应用HTML5和CSS3,一步跨入量前沿。 本书将当前WEB设计中热门的响应式设计技术与HTML5和CSS3结合起来,为读者全面深入地讲解了针对各种屏幕大小设计和开发现代网站的各种技术。不仅讨论了媒体查询、流式布局、...

    揭秘HTML5和CSS3

    揭秘HTML5和CSS3 看看有利无害 欢迎下载

    HTML5和CSS3入门.ppt

    揭秘HTML5和CSS3,是学习HTML5和CSS3非常好的入门材料

    HTML5+CSS3中文参考手册(3手册) chm版中文参考手册打包

    HTML5和CSS3是现代网页开发的基石,它们极大地扩展了网页的表现力和交互性。这份"HTML5+CSS3中文参考手册(3手册) chm版中文参考手册打包"包含两个重要的资源:HTML5和CSS3的中文电子书,为开发者提供了详细的技术...

    html5和css3的权威指南(上下册)的 第三版最新源码

    HTML5和CSS3是现代网页开发的基石,它们极大地丰富了网页的表现力和交互性。这份"HTML5和CSS3的权威指南(上下册)的第三版最新源码"是学习和深入理解这两种技术的重要资源。以下是根据这些知识点的详细说明: **...

    html-5-css-3实训报告,html5和css3知识总结.docx

    HTML5 和 CSS3 是当前 web 开发中最重要的两个技术栈,本文将对 HTML5 和 CSS3 的基本概念、语法、应用场景进行总结和分析。 HTML5 基础知识点 1. HTML5 的文件结构:HTML 文件通常由 head 和 body 两个部分组成,...

    响应式Web设计HTML5和CSS3实战第2版

    资源名称:响应式Web设计 HTML5和CSS3实战 第2版内容简介:本书将当前Web 设计中热门的响应式设计技术与HTML5 和CSS3 结合起来,为读者全面深入地讲解了针对各种屏幕大小设计和开发现代网站的各种技术。书中不仅讨论...

    分享一款黑色大气HTML5和CSS3模板!

    分享一款黑色大气HTML5和CSS3模板!美工非常不错 刚收集了两套设计非常不错的HTML5和CSS3模板,非常适合广告公司,设计公司,婚纱影楼,图片展示类等。 (模板包括可编辑的图像,PSD文件,HTML,JavaScript和CSS文件...

    响应式web设计html5和css3实战 源代码

    HTML5和CSS3是实现响应式设计的关键技术。在“响应式Web设计HTML5和CSS3实战”中,我们将深入探讨如何利用这两种强大的工具来创建灵活、适应性强的网站。 HTML5是超文本标记语言(HTML)的最新版本,引入了许多新...

    HTML5和CSS3期末课程设计

    利用HTML5和CSS3写期末课程设计(稳过的那种)

Global site tag (gtag.js) - Google Analytics