0
点赞
收藏
分享

微信扫一扫

一次性弄懂 meta 标签,看这篇就够了

简介

打开任意网站,其 <head> 标签内都会有很多列的 <meta> 标签。在查阅 w3school 的过程中,第一句话中就包含了 元数据 (元信息)。

<meta> 标签提供关于 HTML 文档的 元数据(meta-information)。元数据 不会显示在页面上,但将被机器解析。

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

详情

meta 标签共有多个属性,分别是:

  • content 属性
  • http-equiv 属性
  • name 属性
  • scheme 属性
  • charset 属性

1. content 属性

它一般是为定义与 http-equiv 或 name 属性相关的元信息,以文本的格式作为其内容。

<meta name="参数" content="这里面是对 name 属性中 参数 具体的描述">。

详细用法,请参考下面的 name 属性。

2. name 属性

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

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

其中 name 属性共有以下几种参数。(前 3 个为常用属性)

2.1 keywords (关键字)

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

<meta name="keywords" content="博客,前端,js">
2.2 description (网站内容的描述)

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

<meta name="description" content="你好,这是本网站的描述~">
2.3 viewport (移动端的窗口)

这个概念较为复杂,具体的在我 另一篇博文 中讲述。这个属性常用于设计移动端网页。在用bootstrap,AmazeUI 等框架时候都需要用 viewport。

<meta name="viewport" content="width=device-width, initial-scale=1">
2.4 robots (定义搜索引擎爬虫的索引方式)

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

<meta name="robots" content="none">

具体参数如下:

  1. none : 搜索引擎将忽略此网页,等价于 noindex,nofollow。
  • noindex : 搜索引擎不索引此网页。

  • nofollow: 搜索引擎不继续通过此网页的链接索引搜索其它的网页。

  1. all : 搜索引擎将索引此网页与继续通过此网页的链接索引,等价于 index,follow。
  • index : 搜索引擎索引此网页。

  • follow : 搜索引擎继续通过此网页的链接索引搜索其它的网页。

2.5 author (作者)

用于标注网页作者

<meta name="author" content="stevechow,zhmnda@icloud.com">
2.6 generator (网页制作软件)

用以说明生成工具(如 dreamweaver)等

<meta name="generator" content="dreamweaver">
2.7 copyright (版权)

用于标注版权信息

<meta name="copyright" content="stevechow"> // 代表该网站为 stevechow 个人版权所有。
2.8 revisit-after (搜索引擎爬虫重访时间)

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

<meta name="revisit-after" content="7 days" >
2.9 renderer (双核浏览器渲染方式)

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

<meta name="renderer" content="webkit"> //默认webkit内核
<meta name="renderer" content="ie-comp"> //默认IE兼容模式
<meta name="renderer" content="ie-stand"> //默认IE标准模式

3. http-equiv 属性

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

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

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

3.1 content-Type (用来设定网页字符集,但推荐使用 HTML5 的方式)

旧的 HTML 才这么使用,不推荐:

<meta http-equiv="content-Type" content="text/html;charset=utf-8"> 

推荐 HTML5 设定网页字符集的方式:

<meta charset="utf-8">
3.2 X-UA-Compatible (浏览器采取何种版本渲染当前页面)

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

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/> // 指定 IE 和 Chrome 使用最新版本渲染当前页面
3.3 cache-control (指定请求和响应遵循的缓存机制)
用法1.(指导浏览器如何缓存某个响应以及缓存多长时间)
<meta http-equiv="cache-control" content="no-cache">

共有以下几种用法:

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

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

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

  4. private:只为单个用户缓存,因此不允许任何中继进行缓存。(比如说CDN就不允许缓存private的响应)

  5. max-age:表示当前请求开始,该响应在多久内能被缓存和重用,而不去服务器重新请求。例如,max-age=60 表示响应可以再缓存和重用 60 秒。

用法2. (禁止百度自动转码)

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

<meta http-equiv="Cache-Control" content="no-siteapp" />
3.4 expires(网页到期时间)

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

<meta http-equiv="expires" content="Sunday 26 October 2016 01:00 GMT" />
3.5 refresh(自动刷新并指向某页面)

网页将在设定的时间内,自动刷新并定向到指定的网址。

<meta http-equiv="refresh" content="2;URL=https://www.jianshu.com/u/e9aa96cb42db"> // 2秒后跳转向我的博客
3.6 Set-Cookie(cookie设定)

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

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

最后

暂时就总结这么多,因为 meta 标签的自定义属性实在太多了,所以只去找了常用的一些。像Window-target这样已被废弃的属性并没有添加。

参考文章

举报

相关推荐

0 条评论