这是补充HTML5基础知识的系列内容,其他为:

周日继续读《HTML5开发手册》,并进行Demo练习,今天主要学习四个HTML5新增的元素:figure、time、details、mark。

不学不知道,原来这些平时不注意的元素都有着很大的功能。好了,下面开始吧。

一、figure、figcaption

在HTML5之前,插入图片时会通过另外的div来包裹图片备注,这样做的缺点在于图片和图注之间没有任何关联。

在HTML5中,可以用figure元素插入某张图片,用figcaption来添加图片备注。

figure通常用来插入图片,但也可以是一段代码、图表、音频或者视频。通常情况下主要用于图片。

<figure>
<img src="" alt="">
<figcaption>
图片标题
</figcaption>
</figure>

建议无论如何在哪种情况下,都要为图片添加alt属性。

figure元素不仅仅可以包含一张图片,还可以包含多张图片:

<figure>
<img src="" alt="" />
<img src="" alt="" />
<img src="" alt="" />
<figcaption>
图片描述
</figcaption>
</figure>

如果单纯的显示图片,使用普通的img标签即可,如果包含了额外信息,那么就应该使用figure和figcaption。

需要注意的是,figure只能包含一个figcaption。

下面练习一下,我们可以实现最常见的广告布局:

<article>
<section>
<h1>More from the Web</h1>
<figure>
<img src="test1.jpg" alt="">
<figcaption>You're Killing Your iPhone With These 7 Charging Mistakes</figcaption>
</figure>
<figure>
<img src="test2.jpg" alt="">
<figcaption>What Was Found After Beats Headphones Were Taken Apart</figcaption>
</figure>
<figure>
<img src="test3.jpg" alt="">
<figcaption>Why You Should Wrap Your Keys In Aluminum Foil</figcaption>
</figure>
<figure>
<img src="test4.jpg" alt="">
<figcaption>The Folding Gun That Looks Like a Smartphone is Worrying Police</figcaption>
</figure>
</section>
</article>

二、time元素插入日期和时间

使用time元素,能够插入计算机能够识别的时间和日期,同时又能以可读的方式显示给用户。利用该元素可以给内容添加如发布时间、事件发生时间等信息。

<time>2017-01-08 10:08</time>

time有两个属性:

  • datetime:计算机识别的时间为datetime属性,用户看到的时间是time标签中的内容
  • pubdate:布尔值,代表最近的父article元素内容的发布时间,如果没有任何的父article元素,则指向整个文档,每个article只能有一个带pubdate属性的time元素。

下面是一个具体的示例:

<article>
<footer>
<p>这篇文章发表自<time pubdate datetime="2012-12-24T16:00">2016年12月24日,下午4点。</time><p>
</footer>
</article>

需要注意的是:datetime属性时间格式必须是公历格式:YYYY-MM-DD,然后加上时间格式:T00:00,24小时制。

综合示例

下面利用上面两个HTML5标签,我们可以优化如下排版(该组件是模仿element的卡片组件):

下面是布局:

<section class="card card--offset">
<figure>
<img class="card__image" src="test.png" alt="好吃的汉堡">
<figcaption class="card__caption">好吃的汉堡</figcaption>
</figure>
<footer class="card__footer">
<p>
<time datetime="2017-01-08T10:08" class="card__time">2017-01-08 10:08</time>
<a href="#" class="card__operation">操作按钮</a>
</p>
</footer>
</section>

我的卡片应用场景是:以图片为主,一个卡片主要用来介绍一组图片,像时间、操作是属于footer的内容,但标题不能算,标题是用来解释图片的,并不是footer的内容,尽管样式上看起来像上下结构。

三、details 创建可伸缩控件

details是个神奇的元素,在无需任何css、js的情况下,创建展开/收缩的开关效果。利用summary标签还可以创建内容的概述信息。

details有一个属性,open,表示默认是打开的。反之默认是关闭的样式。

summary是个可点击的部分,用来控制收缩或展开。

<details open>
<summary>查看详细信息</summary>
<figure>
<img src="xx" alt="xx">
<figcaption>生活照片</figcaption>
</figure>
</details>

details的应用场景就更加多了,比如mac下的查看文件属性布局,接下来会通过details实现更有意思的效果。

四、mark 元素高亮文本

利用mark元素,文档作者可以高亮当前文档的某些文本,以达到醒目的效果。

比如:搜索页面对搜索够关键字进行高亮显示。不选用strong或者em强调这些关键字,仅仅是为用户提供高亮而已。

![屏幕快照 2017-01-08 11.54.17](http://7mj4a6.com1.z0.glb.clouddn.com/2017-01-08-屏幕快照 2017-01-08 11.54.17.png)

五、总结

到目前为止,我们完全可以使用这些新的标签来布局我们的页面,更加语义化更加结构清晰。作为一名前端开发人员更应该将这些最基础的东西熟记下来,撸起袖子继续努力,开发出未来的web应用程序。

六、书籍信息

《HTML5开发手册》

HTML5 Developer's Cookbook

作者:[美]Chuck Hudson [英]Tom Leadbetter

译者:廖望

出版社:人民邮电出版社

读书笔记:《HTML5开发手册》--figure、time、details、mark的更多相关文章

  1. 2017年最重要的HTML5开发手册,传播正能量

    今天给大家推荐这个HTML5开发手册,希望能帮助正在学习web前端的人,鄙人也是刚学习前端没多久,借助于一点资讯平台能够结识更多前端大牛,这是我的HTML5进阶学习一点资讯群:250777811,里面 ...

  2. 2018年最重要的HTML5开发手册,传播正能量

    今天给大家推荐这个HTML5开发手册,希望能帮助正在学习web前端的人,鄙人也是刚学习前端没多久,借助于一点资讯平台能够结识更多前端大牛,这是我的web前端/HTML5/javscript技术学习群: ...

  3. 读书笔记:《HTML5开发手册》--HTML5新的结构元素

    读书笔记:<HTML5开发手册> (HTML5 Developer's CookBook) 虽然从事前端开发已有很长一段时间,对HTML5标签也有使用,但在语义化上面理解还不够清晰.之前在 ...

  4. 读书笔记:《HTML5开发手册》--现有元素的变化

    读书笔记:<HTML5开发手册>-- 现存元素的变化 继续学习HTML5语义化的内容,今天主要介绍一下,HTML5之前的元素经HTML5规范后的语义及一些使用示例. 一.cite HTML ...

  5. 读书笔记:《HTML5开发手册》Web表单

    这是补充HTML5基础知识的第五篇内容,其他为: 一.HTML5-- 新的结构元素 二.HTML5-- figure.time.details.mark 三.HTML5-- details活学活用 四 ...

  6. 读书笔记:《HTML5开发手册》

    一.HTML5中新的结构元素 1. HTML5初始文件 1.1.doctype 在之前,doctype的声明是这样的: <!DOCTYPE HTML PUBLIC "-//W3C//D ...

  7. 读书笔记:《HTML5开发手册》-- 现存元素的变化

    继续学习HTML5语义化的内容,今天主要介绍一下,HTML5之前的元素经HTML5规范后的语义及一些使用示例. 一.cite HTML5对cite元素的定义进行了很大的修改,在HTML4中,cite元 ...

  8. 读书笔记---HTML5实战 MARCO CASARIO(后六章)

    画布叠加:用CSS的z-index和position; 第八章 HTML5通信API ①XMLHTTPREQUEST是JS中用于服务器交互的API; ②用HTML5的POSTMESSAGE API实现 ...

  9. VxWorks 6.9 内核编程指导之读书笔记 -- C++开发

    5.1 介绍 针对C++的VxWorks配置 C++头文件 使用C++启动任务 C和C++之前调用代码 C++编译器说明 在信号处理和ISR中使用C++ 下载C++编写的内核模块 C++编译器的不同 ...

随机推荐

  1. 使用Vundle管理Vim插件

    附:仓库地址 附:我自用的vim配置文件,里面注释很多,仅供参考. Vundle是一款Vim的插件管理软件(Linux),用起来很方便的原因有几点: 支持插件超多,可以来源于github.Vundle ...

  2. 第一次项目冲刺(Alpha版本)2017/11/14

    一.站立式会议 在宿舍进行了第一次会议 会议内容: 1.做了简单的分工 2.提出个人对任务是否有困难 3.规定完成时间在第三天之前 4.商量初步的代码规范 二.分工 三.任务分解图 四.燃尽图 五.数 ...

  3. Web 通信 之 长连接、长轮询(转)

    Web 通信 之 长连接.长轮询(long polling) 基于HTTP的长连接,是一种通过长轮询方式实现"服务器推"的技术,它弥补了HTTP简单的请求应答模式的不足,极大地增强 ...

  4. 【错误记录】记录蛋疼的 mysql 错误

    -- 应用信息表 DROP TABLE IF EXISTS `table_name`; CREATE TABLE `ks_apps_info` ( `id` ) NOT NULL COMMENT 'i ...

  5. 51 nod 1682 中位数计数

    题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1682 1682 中位数计数 基准时间限制:1 秒 空间限制: ...

  6. Linux配置CentOs7.4(网络连接处理)

    说明:CentOS 7.0默认安装好之后是没有自动开启网络连接的! 进入登录界面 账号输入root 回车 再输入上面设置的root密码回车 系统登录成功 设置IP地址.网关DNS cd  /etc/s ...

  7. 随手练——Uva-11584 划分成回文串(区间DP)

    思路:dp[i]代表到第i位的最小值,枚举它的前几位,求出最小值. 转移方程:dp[ i ] = min(dp[ i ], dp[ j - 1 ] + 1 ) ; 本来觉得,代码加深部分可以提前bre ...

  8. 解决IOS9 下在App中无法打开其他应用的问题

    打开 info.plist 文件 ,在根节点下添加下面代码即可,这是由于IOS9新的权限管理机制的问题 <key>LSApplicationQueriesSchemes</key&g ...

  9. GHOST自动恢复说明

    制作一个自己DIY的PE系统,然后自动安装系统使用如下步骤... 1:  首先要解包PE ISO文件,在解压ISO中的WIM文件.使用工具是7Zip,可以直接解压 2:  其次在放入替换的exe文件. ...

  10. 树莓3B+_teamviewer_install

    操作系统 pi@raspberrypi:~ $ uname -a Linux raspberrypi 4.14.79-v7+ #1159 SMP Sun Nov 4 17:50:20 GMT 2018 ...