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

HTML5 CSS3简要教程

阅读更多
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)更上一个台阶。
分享到:
评论

相关推荐

    html5css3简要教程【html5css3培训教程】.pdf

    ...

    html5css3简要教程【html5css3培训教程】.docx

    ...

    前端开发框架bootstrap3教程

    Bootstrap3是一个基于HTML、CSS和JavaScript的开源框架,可以帮助开发者快速构建响应式网站和Web应用程序。 《前端开发框架bootstrap3教程》将介绍Bootstrap3的基本概念和使用方法,包括网格系统、表单、导航、按钮...

    W3school2020离线手册 全套教程 最新中文chm格式

    W3school2020离线手册是CHM格式的,包含HTML/XHTML/HTML5/CSS/XML/PHP/JavaScript/AJAX/JQuery/SQL等文档手册,包含全套教程,需要的朋友可下载试试! 简要描述 完整的网站技术参考手册 参考手册涵盖了网站技术的...

    W3C 教程

    本节内容:简要介绍 W3C 的 HTML。 W3C XHTML 本节总结了 W3C 的 XHTML 活动。 W3C XML 本节总结了 W3C 的 XML 活动。 W3C CSS 本节总结了 W3C 的 CSS 活动。 W3C XSL 本节总结了 W3C 的 XSL 活动。 W3C XML Schema ...

    JavaScript的基本教程.txt

    下面是一个JavaScript的简要教程概述: 一、JavaScript简介与基础 JavaScript最初被称为LiveScript,由Netscape公司的布兰登·艾奇在1995年开发。 JavaScript与HTML和CSS共同构成了网页。HTML用于定义网页内容,...

    简要讲解CSS中的类型选择器、ID选择器、类选择器

    网页元素:在CSS教程中,对于如“&lt;p&gt;&lt;/p&gt;”、“&lt;h3&gt;&lt;/h3&gt;”这些不再称呼为标签,而统一称呼为网页元素。在网页元素中,都可以按类型进行区分,其类型可以作为CSS的选择符,如“&lt;a&gt;&lt;/a&gt;”、“&lt;ul&gt;&lt;/ul&gt;”、“&lt;div&gt;&lt;/...

    CSS教程:理解继承属性及应用

    4.5继承 在本书的[3.3.2继承与层叠]一节曾经简要介绍过继承:(X)HTML元素可以从其父元素那里继承部分CSS属性,即使当前元素并没有定义该属性。 4.5.1值的继承 继承也是基于文档树的,文档树中元素的某些属性可以被...

    jQuery+CSS3折叠卡片式下拉列表框实现效果

    简要教程 HTML结构 该下拉列表框特效的列表项使用一个无序列表来制作,用于切换打开和关闭状态的元素是一个超链接元素。 &lt;i class='fa fa-suitcase'&gt;&lt;/i&gt; &lt;span class='label-active'&gt;Everyting &lt;ul&gt;

    简要总结CSS编程中的响应式设计

    为了帮助你快速入门响应式Web设计,我写了一篇快速入门教程。我保证你通过三步就可以学会响应式设计的基本逻辑和媒体查询(media query)(假设你有基本的CSS知识)。 第一步:Meta标签(看demo)  大部分移动浏览器会...

    网页制作基础教程

    5、在网站建设中,HTML用于搭建页面结构,CSS用于设置页面样式,_______用于为页面添加动态效果。 二、判断题 1、因为静态网页的访问速度快,所以现在互联网上的大部分网站都是由静态网页组成的。( ) 2、网页主要...

    github精选:微信小程序入门简要教程

    .wxss —— Weixin Style Sheets,类似CSS 入口文件 小程序根目录一般有三个文件:app.js、app.json、app.wxss app.json 必须要有这个文件!!否则IDE会报错!这是小程序的配置入口,可对整个小程序进行全局配置,...

    java高级应用教程

    前台的简要制作和后台的搭建,适合初学者,讲解的详细,是开始着手的好教程,希望适合你

    ci-07-love-maths:与CI讲师一起编写代码以构建交互式数学游戏网站

    爱数学概述在Code Institute Full Stack Web开发课程中创建了一个伴随代码的项目。 该项目旨在巩固在JS ... 关于: HTML5 Wiki 创建者: W3联盟CSS3用于提供网站的大多数样式。 关于: CSS3 Wiki 创建者: W3联盟Java

    aos.js动画的用法

    简要教程 aos.js是一款效果超赞的页面滚动元素动画jQuery动画库插件。该动画库可以在页面滚动时提供28种不同的元素动画效果,以及多种easing效果。在页面往回滚动时,元素会恢复到原来的状态。 安装 可以通过bower...

    JJgar2725.github.io:在线投资组合-Jaime Garcia,Jr

    我使用在线简要教程和预制模板创建了一个简单的投资组合。 这个小项目有助于我在Git和Github中学习和实践,并巩固了HTML和CSS中的一些基本概念。 我打算将来从头开始创建一个更自定义的网站。 如果您有任何疑问,或...

    training:万物培训的主要仓库

    3 先进的React React中的规范源(动态) 03-19 4 Git简介,后端pt。 1个 和 将所有内容推送到Git 03-26 5 后端点2个 规格来源API 04-02 6 数据库:MongoDB 与数据库链接的API 04-09 7 捆绑在一起:获取...

    纯javascript移动优先的幻灯片效果

    简要教程 wallop是一款移动优先的纯javascript幻灯片插件。这个幻灯片插件仅4k大小,它的原理仅是为HTML元素添加和移除适当的class来显示和隐藏它们,至于这些class样式你可以完全自定义。特点有: 移动优先 动画和...

    js实现文件上传表单域美化特效

    一款效果非常时尚的文件上传表单域美化特效,下面给出制作的简要教程。 先上几个效果饱饱眼福: 使用方法 这些文件上传域的美化使用的方法都是隐藏原生的&lt;input type=”file”&gt;元素,然后使用一个元素来...

Global site tag (gtag.js) - Google Analytics