互联网科技发展的速度真可谓惊人的快,一个稍不留神,你就可能无法跟上它的步伐。

HTML5的变化和更新也压倒不少人,这篇文章将向大家介绍一些最基本也非常必要的

HTML技巧。

1. 新的文档类型(Doctype)

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

你还在使用上面这个既麻烦又难记的XHTML文档类型吗? 如果还是这样的话,现在该

切换到新的HTML5文档类型了。

 <!DOCTYPE html>

只要这么简单的15个字符就可以了。(注意:你的doctype的申明需要出现在你html文件的第一行。)

2. 图形(Figure)元素

考虑用下面的代码来标记图片?

<img src="path/to/image" alt="About image" />

<p>Image of Mars. </p>

很不幸,它不能用简单、富有语 义关联的方式与图形的标题关联,因为它仅仅是用段落

标记以及图片元素包裹着,而HTML5通过引进<figure>元素,改进了这一点。当结 合

<figcaption> 元素使用时,我们就可以将图形标题与图形配对起来。代码如下:

<figure>
<img src="path/to/image" alt="About image" />
<figcaption>
<p>This is an image of something interesting. </p>
</figcaption>
</figure>

3. 重新定义<small>

原来你可以利用<small>元素来创建与logo密切相关的副标题。不过,现在HTML5修改

了这个用法,<small>元素被重新定义了,或者更恰当地说,它现在用来代表小字或其

他边注(如,网站底部的版权声明)。

4. 不再需要脚本、链接类型

很可能你仍然像下面的代码一样给你的链接和脚本标签添加类型的属性。

<link rel="stylesheet" href="path/to/stylesheet.css" type="text/css" />
<script type="text/javascript" src="path/to/script.js"></script>

在HTML5中,这已经不再需要了。 意味着说这两个标签分别代表着样式和脚本。因此,

我们可以将它们的类型属性都删除掉。代码如下:

<link rel="stylesheet" href="path/to/stylesheet.css" />
<script src="path/to/script.js"></script>

5. 使用还是不使用引号

记住,HTML5与XHTML不同,如果你不喜欢的话你不必用引号将属性包裹起来。不过,

要是你觉得用引号会让你觉得更加舒服的话,当然也不会有任何问题。在这点上,你可以自己决定。

如果你想要一个结构非常清楚的文档的话,坚持使用引号也挺好的。

<p id=someId> Start the reactor.

6. 使你的内容可编辑

 
HTML5其中一个非常强大的功能就是“contenteditable”,顾名思义它将允许用户编辑

元素(包括他的子元素)内包含的任何文本内容。它的用途非常广,如,简单的任务清

单或是基于wiki的站点也非常实用,此外,它还有一个优势就是利用了本地的存储。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>untitled</title>
</head>
<body>
<h2> To-Do List </h2>
<ul contenteditable="true">
<li> Break mechanical cab driver. </li>
<li> Drive to abandoned factory
<li> Watch video of self </li>
</ul>
</body>
</html>

或者,按照第五条技巧所说的,你也可以将第九行的代码写成这样(不用引号):

<ul contenteditable=true>

7. 电子邮件输入

如果我们应用“电子邮件”类型来指定输入的形式,我们可以命令浏览器只允许符合有

效电子邮件地址结构的字符串输入。虽然说内置的表单验证很快就会到来,但是我们也

不能完全依靠这个。比较旧的浏览器不理解这种“电子邮件”类型,它们只会简单地返

回到普通的文本框。

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>untitled</title>
</head>
<body>
<form action="" method="get">
<label for="email">Email:</label>
<input id="email" name="email" type="email" />
<button type="submit"> Submit Form </button>
</form>
</body>
</html>

 
在说到浏览器所支持和不支持的元素以及属性时,你必需知道当前所有浏览器都不是那

么可靠。例如,Opera只有在你指定name属性时才支持电子邮件验证。不过,它不支持

占位符属性(下面即将要讲到的)。最后,虽然你可以使用这种形式的验证,不过不要

过分依赖它。

8. 占位符

此前,我们需要使用JavaScript来创建文本框的占位符。你可以初步设定值属性来看是

否合适,但是只要用户删除了该文本,输入的内容就会再次变成空的。占位符属性有效

地弥补了这一点。

<input name="email" type="email" placeholder="doug@givethesepeopleair.com" />

 
9. 本地存储

多亏了HTML5的 local storage ,我们可以让高级浏览器“记住”我们输入的内容,就

算后来浏览器关闭或者重新刷新也不受影响。尽管不是所有的浏览器都支持,但是最关

键的 Internet Explorer 8, Safari 4, Firefox 3.5.都支持。

10. 语义性的Header和Footer

<div id="header">
...
</div>
<div id="footer">
...
</div>

上面的代码一去不复返。Divs从根本上来说并没有任何语义结构,即使应用上了ID还是如此。

而在HTML5中,我们可以使用<header>和<footer>元素,上面的代码就可以替换

为:

<header>
...
</header>
<footer>
...
</footer>

不过注意不要将这两个元素与网站的头部和脚部混淆起来。它们只是代表它们的容器。

11. IE和HTML5

IE理解新的HTML5元素需要费一定的神,为了确保新的HTML5元素能够以块级元素正

确显示,有必要将它们用下面的代码定义风格:

header, footer, article, section, nav, menu, hgroup {display: block;}

就算如此,IE还是不知道这些元素究竟是什么,因而会无视这些格式,还需要用到下面

的代码来解决这个问题:

document.createElement("article");
document.createElement("footer");
document.createElement("header");
document.createElement("hgroup");
document.createElement("nav");
document.createElement("menu");

12. 群组标题(hgroup)

假设一个网站有名称、副标题分别用<h1>、<h2>标签来标记,在 HTML4中还没有一

种能够将两者之间的关系用很好的语义关系来描述的方法,此外,当使用h2在页面中显

示其它标题时,在层级方面问题就更多。而使用群组 标题hgroup元素,我们可以将这

些标题聚集在一起,而不影响文档的整个纲要。

  <header>
<hgroup>
<h1> Recall Fan Page </h1>
<h2> Only for people who want the memory of a lifetime. </h2>
</hgroup>
</header>

13.必要(Required)属性

表单允许新的必要属性,规定是否某个特定的输入是必要的。你可以依据自己写代码的

偏好,用下面两种不同方式来声明这个属性:

<input type="text" name="someInput" required>

或者,更严谨:

<input type="text" name="someInput" required="required">

上面两行代码都行得通。用了这行代码之后,并且浏览器支持required属性的话, 输入

空白的表单就不会被提交。下面是一个简单的例子,同时我们也添加了占位符属性:

  <form method="post" action="">
  <label for="someInput"> Your Name: </label>
  <input type="text" id="someInput" name="someInput" placeholder="Douglas Quaid" required>
  <button type="submit">Go</button>
</form>

 
如果输入是空的,表单将无法提交,突出显示文本框。

14. 自动对焦(Autofocus)属性

同样地,有了HTML5就不再需要用JavaScript方案来解决自动对焦的问题。如果某个输

入应该被”选择“或被聚焦,我们现在可以使用HTML的自动对焦autofocus属性。

<input type="text" name="someInput" placeholder="Douglas Quaid" required autofocus>


     15. 音频支持
        我们再也不需要依靠第三方插件来提供音频了。HTML5提供了音频元素<audio>。目

   前,只有最新的浏览器支持HTML5音频。 此时,最好还是提供一些向后兼容性。

  
  <audio autoplay="autoplay" controls="controls">
  <source src="file.ogg" />
  <source src="file.mp3" />
  <a href="file.mp3">Download this file.</a>
  </audio>  

说道音频格式,Mozilla和Webkit都还没有完全支持。Firefox希望看到一个 .ogg文

件,Webkit浏览器只支持最常见的.mp3扩展名。这意味着说,至少目前为止,你应该

创建两个版本的音频。当Safari加载页面时,它认 不出.ogg格式的文件,将会跳过并移

到mp3版本上。请注意,IE并不支持它,Opera 10 或更低的版本只支持 .wav文件。

16. 视频支持

与音频元素 <audio>非常像,在新的浏览器上也支持HTML5视频。事实上,就在最近

YouTube宣布了一项新的 HTML5视频嵌入。可 惜的是,由于HTML5说明文件并没有

为视频指出某个特定的编码器,所以都主要取决于浏览器来决定了。尽管Safari和IE9可

以支持H.264 格式的视频,Firefox 和Opera却仍然坚持Theora 和Vorbis格式。因

此,显示HTML5视频的时候,你必须提供两种格式。

17. 视频预先加载

你首先需要决定是否需要浏览器来预先加载视频。是否有需要?假设,一个访客进入某

个专门用来显示视频的页面,那么就非常有必要预先加载这个页面节省一点等待的时

间。你可以通过设置 preload=”preload”来预先加载视频,或者之间添加preload也可以。

18. 显示控件

你可能已经注意到,用上面的代码的话,视频将只会显示成一个图片,而没有任何可控

制的元件。为了获取这些播放控件,我们必需在视频元素里指定这些控件属性。

<video preload>


 
19. 正则表达式

亏了新模式的属性,我们可以直接在代码中插入一个正则表达式。

  <form action="" method="post">
<label for="username">Create a Username: </label>
<input type="text" name="username" id="username" placeholder="4 <> 10" pattern="[A-Za-z]{4,10}" autofocus required>
<button type="submit">Go </button>
</form>

如果你比较熟悉正则表达式的话就会注意到这个新模式: [A-Za-z]{4,10}只接受大小写

字母。这个字符串最少必需有四个字符,最多是十个字符。

20. 检测浏览器对属性的支持

前面提到过并非所有的浏览器都支持这些属性,那是否有什么方法能够判断浏览器是否

能够识别它们呢?这个问题问得非常好,这里给大家介绍两种方式,第一个选择是使用

Modernizr来检测,或者你也可以创建并剖析这些元素来看看浏览器都有什么能力。例

如,在前面的例子里,如果我们要确定浏览器是否能够执行pattern属性,就可以在页面

上添加JavaScript:

   alert( 'pattern' in document.createElement('input') ) // boolean;

实际上,这是确定浏览器兼容性的一种非常常用的方法。jQuery库利用了这个技巧。上

面的代码里,我们创建了一个新的输入元素,并确认pattern属性是否能够被识别。如果

<script>
if (!'pattern' in document.createElement('input') ) {
// do client/server side validation
}
</script>

能够识别的话,浏览器就支持这个功能,否则就不支持。

记住,这将需要依靠 JavaScript来实现!

21. Mark元素

<mark>元素的主要功能就是在页面中高亮显示那些需要在视觉上向用户突出其重要性

的文字。包裹在此 标签里的字符串必须与用户当前的行为相关。例如,如果我在一些博

客中搜索“Open your Mind” ,我可以使用在<mark>标签里使用JavaScript 来包裹

每一次动作。

<h3> Search Results </h3>
<p> They were interrupted, just after Quato said, <mark>"Open your Mind"</mark>. </p>
 

WEB开发人员必知的20+HTML5技巧(转)的更多相关文章

  1. 值得 Web 开发人员收藏的16款 HTML5 工具

    HTML5 正在迅速改变创建和管理网站的方式.HTML5 在不同的领域让网页设计更强大的.快速,安全,响应式,互动和美丽,这些优点吸引更多的 Web 开发人员使用 HTML5 开发各种网站和应用程序. ...

  2. .NET开发人员必知的八个网站

    当前全球有数百万的开发人员在使用微软的.NET技术.如果你是其中之一,或者想要成为其中之一的话,我下面将要列出的每一个站点都应该是你的最爱,都应该收藏到书签中去.对于不熟悉.NET技术的朋友,需要说明 ...

  3. Web开发人员需知的Web缓存知识

    最近的译文距今已有4年之久,原文有一定的更新.今天踩着前辈们的肩膀,再次把这篇文章翻译整理下.一来让自己对web缓存的理解更深刻些,二来让大家注意力稍稍转移下,不要整天HTML5, 面试题啊叨啊叨的~ ...

  4. Web 开发人员需知的 Web 缓存知识

    今天踩着前辈们的肩膀,再次把这篇文章翻译整理下.一来让自己对web缓存的理解更深刻些,二来让大家注意力稍稍转移下,不要整天HTML5, 面试题啊叨啊叨的~~ 什么是Web缓存,为什么要使用它? Web ...

  5. 每个Web开发人员应该知道的12个终端命令

    Tips 原文作者:Danny Markov 原文地址:12 Terminal Commands Every Web Developer Should Know About 终端是开发人员的武器库中最 ...

  6. JavaScript开发人员必知的10个关键习惯

    还在一味没有目的的编写JavaScript代码吗?那么你就OUT了!让我们一起来看看小编为大家搜罗的JavaScript开发人员应该具备的十大关键习惯吧! 随着新技术的不断发展,JavaScript已 ...

  7. Android开发人员必知的开发资源

    developer.android.com 官方开发人员网站推荐资源 在动手编写第一个 Android 应用之前,用心读一读 Android Design 章节.尤其是以下的这些文章: Devices ...

  8. .NET Web开发初学者必知的四个网站

    No.1 W3school 链接: http://www.w3school.com.cn/ 预览: 介绍: 全球最大Web前端技术教程网站.内容涵盖从基础的 HTML 到 CSS到进阶的XML.SQL ...

  9. Web 开发人员不能错过的 jQuery 教程和案例

    jQuery 把惊喜延续到设计领域,处处带来极大的灵活性,创造了许多体验良好的设计,而且拥有不错的性能.这里分享一组 Web 开发人员不能错过的 jQuery 教程和案例,帮助你更好的掌握 jQuer ...

随机推荐

  1. Android实现贪吃蛇游戏

    [绥江一百]http://www.sj100.net                                                  欢迎,进入绥江一百感谢点击[我的小网站,请大家多 ...

  2. jQuery API 3.1.0 速查表-打印版

    jQuery API 3.1.0 速查表-打印图,(API来自:http://jquery.cuishifeng.cn/index.html)

  3. NDIS IM 驱动那些事情

    最近不知道为什么开始学习windows NDIS驱动开发,用的是寒江独钓的例子,其实他的改的代码也就一点点,说的有用的东西也就那么多,不过还是感谢他出了这么一本书,不然这真的就没有一本稍微好一点的书籍 ...

  4. ListView onItemClick(AdapterView<?> parent, View view, int position, long id)参数详解

    public void onItemClick(AdapterView<?> parent, View view, int position, long id) { parent.getA ...

  5. 简单快速的伪Fractional Cascading

    Fractional Cascading算法是用于将零散的多个数组(亦可理解成比较高维的空间)中的数据的二分查找速度增加,用的是空间换时间的方法.然而这种方法并不是很好懂,而且中文文献很少.在这里介绍 ...

  6. OC9_字符串的内存管理

    // // main.m // OC9_字符串的内存管理 // // Created by zhangxueming on 15/6/18. // Copyright (c) 2015年 zhangx ...

  7. (转)实战Memcached缓存系统(8)Memcached异步实时读写问题的解决方案SAC

    在使用Memcached时,一般实时读写的场景并不多见.但多是Memcached写入后,在一定时间后才会有读操作.但是如果应用场景,是写入后瞬间即会有读操作呢?似乎没有什么特别之处,我们依然可以这样写 ...

  8. jQuery实现列表自动滚动

    需要在页面中一个小的区域循环滚动展示新闻(公告.活动.图片等等),并且,鼠标悬停时停止滚动并提示,离开后,继续滚动. 效果图:    上干货 html: <div id="news&q ...

  9. JavaScript jQuery 入门回顾 2

    JQuery 滑动 利用jQuery可以在元素上创建滑动效果. slideDown() 向下滑动元素. slideUp() 向上滑动元素. slideToggle() 在 slideDown() 与 ...

  10. Servlet实现web站点文件下载功能示例

    前段时间事情比较多,导致二月份没有记录自己的学习情况.最近接触了servlet,参考韩老师的教程自己写了一个web站点文件下载的小项目,该项目中还加入了简单的反盗链技术. 1.首先创建一个Shared ...