HTML5 CSS3简要教程
虽然我们现在已经普遍使用了HTML4和CSS2.1,但是我们还可以做得更好!我们可以重组我们代码的结构并能让我们的页面代码更富有语义化特性。我们 可以缩减带给页面美丽外观样式代码量并让他们有更高的可扩展性。现在,HTML5和CSS3正跃跃欲试的等待大家,下面就跟兄弟连HTML5培训来看看他们是否真的能让我们 的设计提升到下一个高度吧…
跟<div>说再见,欢迎语义化标签
曾经,设计师们经常会跟频繁使用基于table的没有任何语义的布局。不过最终还是要感谢像Jeffrey Zeldman和Eric Meyer这样的思想革新者,聪明的设计师们慢慢的接受了相对更语义化的<div>布局替代了table布局,并且开始调用外部样式表。但不 幸的是,复杂的网页设计需要大量不同的标签结构代码,我们把它叫做“<div>-soup” 综合症。也许你很熟悉下面的代码:
<divid=”news”>
<divclass=”section”>
<divclass=”article”>
<divclass=”header”>
<h1>Div Soup Demonstration</h1>
<p>Posted on July 11th, 2009</p>
</div>
<divclass=”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>
<divclass=”footer”>
<p>Tags: HMTL, code, demo</p>
</div>
</div>
<divclass=”aside”>
<divclass=”header”>
<h1>Tangential Information</h1>
</div>
<divclass=”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>
<divclass=”footer”>
<p>Tags: HMTL, code, demo</p>
</div>
</div>
</div>
< /div>
尽管这有些勉强,但上面这个实例还是可以说明使用HTML4对一个复杂的设计进行代码化后依然过于臃肿(其实xHTML1.1也不过如此)。不过值 得激动的是,HTML5解决“<div>-soup” 综合症并带给我们一套新的结构化元素。这些新的HTML5元素富有更细致的语义从而代替了那些毫无语义的<div>标签,并同时为CSS的调 用提供了”自然”的CSS钩子。下面是兄弟连(www.lampbrother.net)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的。
正如我们所见,HTML5可以让我们用很多更语义化的结构化代码标签代替那些大量的无意义的
标签。这种语义化的特性不仅提升了我们网页的质量和语义,并且大量减少了曾经代码中用于CSS必须调用的class和id属性。事实上,CSS3也是可以然通过我们忽略掉所有 class和id的。
结合了富有新的语义化标记的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]: EF
* 兄弟选择器:[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>元素也许可以这样定位:
1
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”选择器了:
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>
我们可以仅使用以下一行选择器:
section>section:only-of-type {}
总结
我相信随着时间的推进和更多浏览器的支持,HTML5和CSS3将越来越受欢迎,它们将为web设计师们带来更无穷的能量,让我们的web前端(www.lampbrother.net)更上一个台阶。
分享到:
相关推荐
HTML5和CSS3是现代网页开发的两大核心技术,它们带来了许多改进和创新,极大地提升了Web设计的效率和用户体验。在HTML5中,重点在于引入了更具有语义性的标签,以帮助网页内容更好地表达其含义,同时减少了对标签的...
HTML5和CSS3是现代网页开发的两大核心技术,它们极大地提升了网页设计的灵活性和用户体验。在HTML5中,语义化的标签使得网页内容更加结构化,而CSS3则提供了更强大的样式控制和动画效果。 首先,HTML5引入了一系列...
**CSS教程(PPT)** **一、CSS简介** CSS(Cascading Style Sheets)层叠样式表,是一种用于描述HTML或XML(包括如SVG、MathML等各种XML方言)文档样式的样式表语言。CSS能够让你独立于内容来控制网页的布局,使网页...
CSS部分紧接HTML,首先简要介绍了CSS的基本概念和语法,包括颜色、文字、超链接、列表和简单导航栏等。接着,教程深入讲解了CSS中的盒模型、定位和浮动等核心概念,以及如何利用CSS进行图片、背景和布局的设置。在...
4. **布局与样式**:虽然CSS是独立的主题,但在这里会简要介绍如何通过内联样式、内部样式表和外部样式表来设置HTML元素的样式。 然后,CSS(Cascading Style Sheets)是用于定义网页外观和布局的样式语言,课程...
在CSS教程中,还介绍了在HTML中引入CSS的几种方法,包括行内式、嵌入式、导入式和链接式。行内式直接在HTML元素内通过style属性使用,嵌入式则是在HTML文档的头部定义style标签内写入CSS规则,导入式使用@import导入...
在探讨DIV+CSS布局之前,我们先来简要回顾一下CSS和HTML的基本概念。HTML(HyperText Markup Language),即超文本标记语言,是用于创建网页的标准标记语言。而CSS(Cascading Style Sheets),层叠样式表,则是一种...
本教程将深入讲解如何利用jQuery和CSS3技术,将普通的`range`滑块转化为具有斑马线样式的高级特效,以提升用户界面的视觉吸引力和交互性。 首先,我们要了解CSS3在这一过程中的作用。CSS3引入了许多新的选择器和...
《DIV+CSS教程—十天学会web标准div+css标准之路》是一份全面且深入的教程,旨在帮助初学者在短时间内掌握网页布局的核心技术——DIV和CSS。此教程以Word文档的形式提供,易于阅读和打印,适合自学或者作为教学参考...
本教程将详细讲解如何使用HTML+CSS实现一个个人网页模板,并简要提及JavaScript在其中的作用。 首先,HTML是用来结构化网页内容的标记语言。它通过不同的标签来定义网页的各种元素,如标题(`<h1>`到`<h6>`)、段落...
总的来说,《Head First HTML与CSS》是一本非常适合初学者的教程,它通过直观易懂的方式讲解HTML和CSS,使读者能够在愉快的学习过程中建立起扎实的Web开发基础。无论你是想成为一名Web开发者,还是单纯地想了解网页...
**CSS(层叠样式表)教程** CSS,全称Cascading Style Sheets,是一种用于描述HTML或XML(包括如SVG、MathML等各种XML方言)文档...希望这个简要的教程能为初学者提供良好的起点,助你在网页设计的道路上更进一步。
压缩包内的"使用说明-.txt"可能是教程的阅读指南或操作步骤,它可能包含了如何逐步学习HTML的建议,或者对HTML基础知识的简要概述。"帮助.url"是一个快捷方式,可能指向一个有关HTML的在线资源或论坛,供学习者在...
在本文中,我们将重点讨论CSS编程的基础知识,并简要介绍如何使用Code Composer Studio(CCS)作为DSP(Digital Signal Processing)编程的调试工具。 CSS编程基础: 1. 选择器与属性:CSS通过选择器定位HTML元素,...
2. **说明.htm**:这个文件可能是学习资源的介绍或指南,涵盖了使用此包学习CSS1的建议、注意事项,或者对包含的教程和示例的简要概述。 3. **readme.txt**:标准的“阅读我”文件,通常提供关于压缩包内容的简短...
这个CSS英文小字典包含了160个与CSS相关的专业词汇,旨在解决开发者在阅读文档、教程或代码时可能遇到的困惑。每个词汇都有详尽的解释,帮助读者快速掌握概念,提升学习效率。以下是一些关键CSS概念的简要介绍: 1....
9. **CSS基础**:虽然CSS不在HTML范畴内,但作为美化HTML的重要手段,教程会简要介绍CSS的基本概念和语法,如选择器、属性和值,以及如何将CSS与HTML结合。 10. **响应式设计**:讲解如何利用媒体查询(media ...
本教程将探讨如何规划Flask项目的结构,并提供一个简要的教程来帮助你快速上手。 首先,理解Flask项目的标准结构至关重要。一个基本的Flask应用通常包括以下几个部分: 1. **主程序文件 (app.py)**:这是启动Flask...
Bootstrap3是一个基于HTML、CSS和JavaScript的开源框架,可以帮助开发者快速构建响应式网站和Web应用程序。 《前端开发框架bootstrap3教程》将介绍Bootstrap3的基本概念和使用方法,包括网格系统、表单、导航、按钮...
《Wrox.Beginning.HTML.XHTML.CSS.and.JavaScript.Dec.2009》这本书是Web开发领域的一本经典教程,特别适合初学者入门。它全面涵盖了HTML、XHTML、CSS和JavaScript这四种关键技术,帮助读者构建扎实的前端开发基础。...