HTML5 快速学习一
关注HTML5有一段时间了,一直没系统的去学习过。
对于HTML5的理解,之前停留在一些新的标签,一些api可以完成部分js完成的事情,仅此而已。
前段时间HTML5定稿了,看了一些这方面的报道,进行了系统的学习,HTML5能做的远比你想象的多。
是时候开始学习了。
本系列内容主要参考"HTML5高级程序设计"和W3SCHOOL.
本文是系列的第一篇: HTML5初窥。
文章提纲
- 概述
- HTML5发展史 & 设计理念
- HTML5新功能快速预览
- 总结
概述
随着未来桌面移动化进程的逐渐普及, 移动设备与桌面设备使用的技术架构不可避免会有趋同的走势,HTML5 是唯一通吃 PC、Mac、iPhone、iPad、Android、Windows Phone 等主流平台的跨平台语言, 是时候采用HTML5+CSS3+JS构建新的Web应用了。
作为下一代Web语言,HTML5不再只是一种标记语言,它为下一代Web提供了全新的框架和平台,包括提供免插件的音频视频、图像动画、本地存储及更多酷炫的功能,是Web能够轻松实现native的体验。
HTML5发展史&设计理念
HTML5发展史
我把HTML5的发展史概括成三句话,详细内容有兴趣自己查阅,我就不多说了。
1993年HTML首次以因特网草案的形式发布,从2.0,3.2,4.0直到1999年的4.01版,4.01后开始停滞不前,W3C掌握着HTML规范的控制权。
一组人2004年成立了WHATWA(Web Hypertext Application Technology Working Group), 他们创立了HTML5规范, 同时针对Web应用开发新功能。(Web 2.0就是这个时候被发明的)
2006年,W3C又重新介入HTML,并于2008年发布了HTML5的工作草案,上个月正式定稿。
HTML5设计理念
1. 兼容性
支持现有文档并保持平滑过渡。
例如Google分析了上百万的页面,从中分析出DIV标签的通用ID名称,发现其中重复量很大, 很多开发人员都喜欢用DIV id="header"来标记页眉区域。HTML5于是直接定义了一个<header>标签。
2. 实用性(效率和用户优先)
HTML5规范是基于用户优先准则编写的,其宗旨是"用户至上",这意味着遇到无法解决的冲突时,规范会把用户放到第一位,其次是页面作者,再次是实现者(浏览器),最后才考虑到理论的纯粹性。
3. 化繁为简
主要做了以下改进:
以浏览器原生能力代替复杂的js代码;
新的简化的DOCTYPE;
新的简化的字符集声明;
简单而强大的HTML5 API;
4. 通用访问性
这个原则分为三个概念。
可访问性:出于对残障人士考虑,HTML5和WAI(Web Accessibility Initiative)和ARIA(Accessible Rich Internet Applications)做了紧密结合,WAI-ARIA中以屏幕阅读器为基础的元素已经被添加到HTML中。
媒体中立:如果可能的话,HTML5的功能在所有不同的设备和平台上应该都能正常运行。
支持所有语种:例如,新的<ruby>元素支持在东亚页面排版中会用到的Ruby注释。
Note
<ruby>定义和用法:
<ruby> 标签定义 ruby 注释(中文注音或字符)。
在东亚使用,显示的是东亚字符的发音。
与 <ruby> 以及 <rt> 标签一同使用:
ruby 元素由一个或多个字符(需要一个解释/发音)和一个提供该信息的 rt 元素组成,还包括可选的 rp 元素,定义当浏览器不支持 "ruby" 元素时显示的内容。

HTML5新功能快速预览
新的DOCTYPE和字符集
根据上面提到的HTML5设计准则化繁为简,Web页面的DOCTYPE被极大的简化了。
HTML4 DOCTYPE
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <!DOCTYPE>
谁能记得住?
请看HTML5 DOCTYPE
<!DOCTYPE html>
跟DOCTYPE一样,字符集的声明也被简化了。
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
现在成了
<meta charset=utf-8" />
新元素和旧元素
HTML5标记元素根据内容类型的不同,分成7大类:
内嵌
像文档中添加其他类型的内容,例如audio、video、canvas和iframe等
流
在文档和应用的body中使用的元素,例如form、h1和small等
标题
段落标题,例如h1、h2和hgroup等
交互
与用户交互的内容,例如button和textarea等
元数据
通常出现在页面的head中,设置页面其他部分的表现和行为,例如script、style和title等
短语
文本和文本标记元素,例如mark、kbd、sub和sup等
片段
用于定义文档中片段的元素,例如article、aside和title等
语义化标记
HTML5新的片段类元素介绍
header
标记头部区域的内容(用于整个页面或页面中的一块区域)
footer
标记脚部区域的内容(用于整个页面或页面中的一块区域)
section
web页面中的一块区域
article
独立的文章内容
aside
相关内容或引文
nav
导航类辅助内容
下面是一个标签位置的示意图

使用Selectors API简化选取操作
除了语义化元素外,HTML5还引入了一种用于查找页面DOM元素的快捷方式。
HTML5之前查找元素的js举例:
函数:getElementById()
举例:<div id="foo"> getElementById("foo")
HTML5有了新的Selectors API, 可以用更精确的方式来指定希望获取的元素,而不必再用标准的DOM的方式循环遍历。使用方式类似于CSS中使用的选择规则一样。举例:
函数1:querySelector()
描述:根据指定的选择规则,返回在页面中找到的第一个匹配元素
示例:querySelector("input.error")
结果:返回第一个CSS类名为"error"的文本选择框
------------
函数2:querySelectorAll()
描述:根据指定规则返回页面中所有相匹配的元素
示例:querySelectorAll("#results td")
结果:返回id值为results的元素下所有的单元格
Note
1. 可以为Selector API函数同时指定多个规则,例如
//选择文档中名为highClass或lowClass的第一个元素
var x= document.querySelector(".highClass",".lowClass");
2. Selectors API不仅仅只是方便,在遍历DOM的时候,
Selectors API通常会比以前的遍历搜索更快,浏览器对选择器匹配进行了高度优化。
window.JSON
JSON作为js语法的一个子集,它将数据表示为对象字面量。
由于其语法简单和在js编程中与生俱来的兼容性,JSON变成了HTML5应用内部数据交换的事实标准。
典型的JSON API包含两个函数,parse()和stringify(), 分别用于将字符串序列化成DOM对象和将DOM对象转换成字符串。
如果旧的浏览器使用JSON,需要js库。
在js中执行解析和序列化效率往往不高,所以为了提高执行速度,新的浏览器原生扩展了对JSON的支持,可以直接通过js来调用JSON了。
总结
本文首先介绍了HTML5的一些重要特点,HTML的历史和设计理念。
最后对HTML5的新功能进行了快速预览。
赶紧抽时间学习HTML5吧!
好了,今天就到这里。
欢迎大家多多评论,让下一篇文章更好 :)
HTML5 快速学习一的更多相关文章
- HTML5 快速学习二 Canvas
本篇文章开始讲解HTML5的核心功能之一:Canvas 通过Canvas可以动态生成和展示图形.图表.图像以及动画. Canvas API功能非常多,我们将讨论最常用的功能. 我们先新建一个canva ...
- 数百个 HTML5 例子学习 HT 图形组件 – WebGL 3D 篇
<数百个 HTML5 例子学习 HT 图形组件 – 拓扑图篇>一文让读者了解了 HT的 2D 拓扑图组件使用,本文将对 HT 的 3D 功能做个综合性的介绍,以便初学者可快速上手使用 HT ...
- 数百个 HTML5 例子学习 HT 图形组件 – 拓扑图篇
HT 是啥:Everything you need to create cutting-edge 2D and 3D visualization. 这口号是当年心目中的产品方向,接着就朝这个方向慢慢打 ...
- HTML5 例子学习 HT 图形组件
HTML5 例子学习 HT 图形组件 HT 是啥:Everything you need to create cutting-edge 2D and 3D visualization. 这口号是当年心 ...
- 数百个 HTML5 例子学习 HT 图形组件 – 3D建模篇
http://www.hightopo.com/demo/pipeline/index.html <数百个 HTML5 例子学习 HT 图形组件 – WebGL 3D 篇>里提到 HT 很 ...
- 数百个 HTML5 例子学习 HT 图形组件 – 3D 建模篇
http://www.hightopo.com/demo/pipeline/index.html <数百个 HTML5 例子学习 HT 图形组件 – WebGL 3D 篇>里提到 HT 很 ...
- 60分钟Python快速学习(给发哥一个交代)
60分钟Python快速学习 之前和同事谈到Python,每次下班后跑步都是在听他说,例如Python属于“胶水语言啦”,属于“解释型语言啦!”,是“面向对象的语言啦!”,另外没有数据类型,逻辑全靠空 ...
- LinqPad工具:帮你快速学习Linq
LinqPad工具:帮你快速学习Linq 参考: http://www.cnblogs.com/li-peng/p/3441729.html ★:linqPad下载地址:http://www.linq ...
- HTML5 CSS3学习
HTML5 CSS3学习 :http://www.1000zhu.com/course/css3/ HTML5 相关书籍: http://www.html5cn.com.cn/news/gdt/2 ...
随机推荐
- EZ 2018 03 30 NOIP2018 模拟赛(六)
链接:http://211.140.156.254:2333/contest/67 转眼间上次加回来的Rating又掉完了. 这次不知为何特别水,T1想了一段时间没想出来弃了,导致后面心态炸了. T2 ...
- Google是如何教会机器玩Atari游戏的
转自:http://blog.csdn.net/revolver/article/details/50177219 今年上半年(2015年2月),Google在Nature上发表了一篇论文:Human ...
- 继承类中static数据值
class A{ static int num = 1; public static void Display(){ System.out.println( num ); } } class B ex ...
- 分布式Redis缓存串讲(一)
互联网应用的基石 现在流量稍微大些的网站,都会采取Redis.基于Redis的内存缓存特性,可以大幅度降低数据库的访问量,大大提升了网站的并发能力,充当数据库的削量先锋.既然Redis这么重要,我们从 ...
- C#用Infragistics 导入导出Excel(一)
最近项目中有数据的导入导出Excel的需求,这里做简单整理. 公司用的是Infragistics的产品,付费,不需要本地安装Office. 有需要的朋友可以下载 Infragistics.2013.2 ...
- JavaScript高级程序设计学习笔记2
垃圾收集原理: 找出不再使用的变量,然后释放其内存. js中最常用的垃圾收集方法是标记清除,当变量进入环境时,就将变量标记为“进入环境”,当变量离开环境时,将其标记为“离开环境”,最后由垃圾收集器完成 ...
- Manjaro Linux 没有声音
在Multimedia中的PulseAudio Volume Control中的设置可以解决
- ElasticSearch 2 (26) - 语言处理系列之打字或拼写错误
ElasticSearch 2 (26) - 语言处理系列之打字或拼写错误 摘要 我们喜欢在对结构化数据(如:日期和价格)做查询时,结果只返回那些能精确匹配的文档.但是,好的全文搜索不应该有这样的限制 ...
- PAT 1044 火星数字
https://pintia.cn/problem-sets/994805260223102976/problems/994805279328157696 火星人是以13进制计数的: 地球人的0被火星 ...
- Citrix Merchandising Server 配置
获取Citrix Merchandising Server虚拟镜像: 我们可以从Citrix官网上下载Citrix Merchandising Server(分为XenServer和vSphere), ...