html5基础篇(二)

构造页面

现在,已经了解了创建一个 HTML5 页面所需的基本标记,接下来让我们开始正式构造页面。

让我们开始构造页面吧。首先,让我们先关注一下 <!doctype>。在 HTML5 中,对 <!doctype>进行了简化:您只需要记住 html即可。这不仅简化了标记的输入,而且该标记在以后也不需要进行修改。注意,它不是 html5,而是 html。不管 HTML 以后会有多少个版本,<!doctype>只能是 html

<html>标记包含除 <!doctype>以外的所有其他 HTML 元素。所有这些元素都应当被嵌套到 <html>和 </html>标记之间。

清单2.1<!doctype>标记实例

<!doctype html> 
<html lang="en">

表明文档类型为 html和使用语言为英语后,将要使用 <head>元素。该元素将包含脚本、浏览器支持信息、样式表链接、元信息和其他初始化功能。可以在 head部分中使用以下标记:

•  <base>

•  <link>

•  <meta>

•  <script>

•  <style>

•  <title>

<base> 标签为页面上的所有链接规定默认地址或默认目标。

通常情况下,浏览器会从当前文档的 URL 中提取相应的元素来填写相对 URL 中的空白。

使用 <base> 标签可以改变这一点。浏览器随后将不再使用当前文档的 URL,而使用指定的基本 URL 来解析所有的相对 URL。这其中包括 <a>、<img>、<link>、<form> 标签中的 URL。

<head>
    <base href="http://www.w3school.com.cn/i/" />
    <base target="_blank" />
</head>
<body>
   <img src="eg_smile.gif" />
    <a href="http://www.w3school.com.cn">W3School</a>
</body>

  

<link> 标签定义文档与外部资源的关系。最常见的用途是链接样式表。

<head>
    <link rel="stylesheet" type="text/css" href="theme.css" />
</head>

<meta>常用于定义页面的说明,关键字,最后修改日期,和其它的元数据。这些元数据将服务于浏览器(如何布局或重载页面),搜索引擎和其它网络服务。

<meta>标签共有两个属性,分别是http-equiv属性和name属性。

请注意: 全局属性 name 在 <meta> 元素中具有特殊的语义;另外, 在同一个 <meta> 标签中,name, http-equiy 或者 charset 三者中任何一个属性存在时,itemprop 属性不能被使用。

charset

此特性声明当前文档所使用的字符编码,但该声明可以被任何一个元素的 lang 特性的值覆盖。此特性的值必须是一个符合由IANA所定义的字符编码首选MIME 名称(preferred MIME name )之一。尽管标准不要求必须使用某些特定的字符编码,但它还是给出了一些建议:

•  鼓励使用 UTF-8;

•  不应该使用不兼容ASCII的编码规范, (i.e. those that don't map the 8-bit code points 0x20 to 0x7E to the Unicode 0x0020 to 0x007E code points) 以避免不必要的安全风险:browsers not supporting them may interpret benign content as HTML Elements. This is the case of at least the following charsets: JIS_C6226-1983, JIS_X0212-1990, HZ-GB-2312, JOHAB, the ISO-2022 family, and the EBCDIC family.

•  绝对不能使用CESU-8、UTF-7、BOCU-1以及SCSU这一类编码,由于这些编码而引起的跨站脚本攻击已经被记录在案。

•  不应该使用 UTF-31,因为不是所有的 HTML5 编码算法都能将它与 UTF-16 区分开来。

 content

基于内容,这个属性为 http-equiv 或 name 属性提供了与其相关的值的定义.

 http-equiy属性

这个枚举属性定义了能改变服务器和用户引擎行为的编译。

meta标签中http-equiv属性语法格式是:

<meta http-equiv="参数" content="具体的描述">

  其中http-equiv属性主要有以下几种参数:

A.  content-Type(设定网页字符集)(推荐使用HTML5的方式)

说明:用于设定网页字符集,便于浏览器解析与渲染页面。

举例:

<meta http-equiv="content-Type" content="text/html;charset=utf-8">  //旧的HTML,不推荐

<meta charset="utf-8"> //HTML5设定网页字符集的方式,推荐使用UTF-8

B. X-UA-Compatible(浏览器采取何种版本渲染当前页面)

说明:用于告知浏览器以何种版本来渲染页面。(一般都设置为最新模式,在各大框架中这个设置也很常见。)

举例:

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/> //指定IE和Chrome使用最新版本渲染当前页面

C. cache-contorl(指定请求和响应遵循的缓存机制)

用法1

说明:指导浏览器如何缓存某个响应以及缓存多长时间。

举例:

<meta http-equiv="cache-control" content="no-cache">

共有以下几种用法:

•  no-cache: 先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存。

•  no-store: 不允许缓存,每次都要去服务器上,下载完整的响应。(安全措施)

•  public : 缓存所有响应,但并非必须。因为max-age也可以做到相同效果

•  private : 只为单个用户缓存,因此不允许任何中继进行缓存。(比如说CDN就不允许缓存private的响应)•  maxage : 表示当前请求开始,该响应在多久内能被缓存和重用,而不去服务器重新请求。例如:max-age=60表示响应可以再缓存和重用 60 秒。

用法2:

说明:用于禁止当前页面在移动端浏览时,被百度自动转码。虽然百度的本意是好的,但是转码效果很多时候却不尽人意。所以可以在head中加入例子中的那句话,就可以避免百度自动转码了。

举例:

<meta http-equiv="Cache-Control" content="no-siteapp" />

D. expires(网页到期时间)

说明:用于设定网页的到期时间,过期后网页必须到服务器上重新传输。
举例:

<meta http-equiv="expires" content="Sunday 26 October 2016 01:00 GMT" />

  E. refresh(自动刷新并指向某页面)

说明:网页将在设定的时间内,自动刷新并调向设定的网址。
举例:

<meta http-equiv="refresh" content="2;URL=http://www.lxxyx.win/"> //意思是2秒后跳转向我的博客

F.  Set-Cookie(cookie设定)

说明:如果网页过期。那么这个网页存在本地的cookies也会被自动删除。

举例:

<meta http-equiv="Set-Cookie" content="name, date"> //格式

<meta http-equiv="Set-Cookie" content="User=Lxxyx; path=/; expires=Sunday, 10-Jan-16 10:00:00 GMT"> //具体范例

  

name属性

name属性主要用于描述网页,比如网页的关键词,叙述等。与之对应的属性值为content,content中的内容是对name填入类型的具体描述,便于搜索引擎抓取。

meta标签中name属性语法格式是:

<meta name="参数" content="具体的描述">

  其中name属性共有以下几种参数:

•  keyword:用于告诉搜索引擎,你网页的关键字。

•  description:用于告诉搜索引擎,你网站的主要内容。

•  viewpoint:这个概念较为复杂,具体的会在下篇博文中讲述。这个属性常用于设计移动端网页。在用bootstrap,AmazeUI等框架时候都有用过viewport。

•  robots: 用来告诉爬虫哪些页面需要索引,哪些页面不需要索引。content的参数有all,none,index,noindex,follow,nofollow。默认是all。

        •  author : 用于标注网页作者。

        •  generator : 用于标明网页是什么软件做的。

•  copyright : 用于标注版权信息。

•  revisit-after:如果页面不是经常更新,为了减轻搜索引擎爬虫对服务器带来的压力,可以设置一个爬虫的重访时间。如果重访时间过短,爬虫将按它们定义的默认时间来访问。

•  renderer:renderer是为双核浏览器准备的,用于指定双核浏览器默认以何种方式渲染页面。比如说360浏览器。

举例:

<meta name="keywords" content="Lxxyx,博客,文科生,前端">
<meta name="description" content="文科生,热爱前端与编程。目前大二,这是我的前端博客">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="robots" content="none">
<meta name="author" content="Lxxyx,841380530@qq.com">
<meta name="generator" content="Sublime Text3">
<meta name="copyright" content="Lxxyx"> //代表该网站为Lxxyx个人版权所有。
<meta name="revisit-after" content="7 days" >
<meta name="renderer" content="webkit"> //默认webkit内核
<meta name="renderer" content="ie-comp"> //默认IE兼容模式
<meta name="renderer" content="ie-stand"> //默认IE标准模式

  

 

posted @ 2017-09-06 16:29  苏皖  阅读(118)  评论(0编辑  收藏  举报