最近通过meta标签控制referrer策略的应用后,想深入了解meta标签

元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词。 标签位于文档的头部,不包含任何内容。 标签的属性定义了与文档相关联的名称/值对。

运行环境 Runtime environment

1
2
3
操作系统: Windos10  
IDE: webStrom 2021.3.1 x64
语言: HTML

定义

元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词。 标签位于文档的头部,不包含任何内容。 标签的属性定义了与文档相关联的名称/值对。

HTML 与 XHTML 之间的差异

在 HTML 中, 标签没有结束标签。

在 XHTML 中, 标签必须被正确地关闭。即:


提示和注释

注释: 标签永远位于 head 元素内部。

注释:元数据总是以名称/值的形式被成对传递的。


属性和值的用法

必须属性

name 属性

name 属性提供了名称/值对中的名称。HTML 和 XHTML 标签都没有指定任何预先定义的 名称。通常情况下,您可以自由使用对自己和源文档的读者来说富有意义的名称。

“keywords” 是一个经常被用到的名称。它为文档定义了一组关键字。某些搜索引擎在遇到这些关键字时,会用这些关键字对文档进行分类。

类似这样的 meta 标签可能对于进入搜索引擎的索引有帮助:

1
<meta name="keywords" content="HTML,ASP,PHP,SQL">

如果没有提供 name 属性,那么名称/值对中的名称会采用 http-equiv 属性的值。

可选属性

http-equiv 属性

http-equiv 属性为名称/值对提供了名称。并指示服务器在发送实际的文档之前先在要传送给浏览器的 MIME 文档头部包含名称/值对。

当服务器向浏览器发送文档时,会先发送许多名称/值对。虽然有些服务器会发送许多这种名称/值对,但是所有服务器都至少要发送一个:content-type:text/html。这将告诉浏览器准备接受一个 HTML 文档。

使用带有 http-equiv 属性的 标签时,服务器将把名称/值对添加到发送给浏览器的内容头部。例如,添加:

1
2
3
<meta name="referrer" content="no-referrer|no-referrer-when-downgrade|origin|origin-when-crossorigin|unsafe-url">
<meta http-equiv="charset" content="iso-8859-1">
<meta http-equiv="expires" content="31 Dec 2008">

这样发送到浏览器的头部就应该包含:

1
2
3
content-type: text/html
charset:iso-8859-1
expires:31 Dec 2008

当然,只有浏览器可以接受这些附加的头部字段,并能以适当的方式使用它们时,这些字段才有意义。

content 属性

content 属性提供了名称/值对中的值。该值可以是任何有效的字符串。

content 属性始终要和 name 属性或 http-equiv 属性一起使用。

scheme 属性

scheme 属性用于指定要用来翻译属性值的方案。

此方案应该在由 标签的 profile 属性指定的概况文件中进行了定义。


常用方法示例

  1. <meta name=”参数” content=”具体的描述”>
  • keywords:网页关键字
1
<meta name="keywords" content="otaku,sex">
  • description:网站内容的描述,网站主要内容
1
<meta name="description" content="holy shit">
  • viewport:移动端视口,仅供移动设备使用
1
<meta name="viewport" content="width=device-width, initial-scale=1">
  • robots:搜索引擎爬虫的索引方式,content不填默认为all
1
<meta name="robots" content="all|none|index|noindex|follow|nofollow">

none : 搜索引擎将忽略此网页,等价于noindex,nofollow

noindex : 搜索引擎不索引此网页

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

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

index : 搜索引擎索引此网页

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

  • author:作者

    1
    <meta name="author" content="Sheldon">
  • author:作者

    1
    <meta name="author" content="Sheldon">
  • revisit-after:搜索引擎爬虫重访时间

    1
    <meta name="revisit-after" content="one week" >
  • copyright:标注版权信息

    1
    <meta name="copyright" content="RaXianch"> //代表该网站为RaXianch版权所有
  1. <meta http-equiv=”参数” content=”具体的描述”>
  • content-Type:声明字符编码

    1
    2
    <meta charset="utf-8">  // H5新增,推荐使用
    <meta http-equiv="content-Type" content="text/html;charset=utf-8"> //旧的HTML
  • cache-control:指定请求和响应遵循的缓存机制

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

    content的值:

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

    no-store: 不允许缓存,每次都要去服务器上,下载完整的响应

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

    private : 只为单个用户缓存,因此不允许任何中继进行缓存

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

    no-siteapp:禁止百度自动转码

  • expires:网页到期时间,到期后网页必须到服务器上重新传输。

    1
    <meta http-equiv="expires" content="Sunday 26 October 2018 10:00 GMT" />
  • refresh:自动刷新并指向某页面

    1
    <meta http-equiv="refresh" content="2; URL=http://www.sina.com/"> //意思是2秒后跳转新浪
  • X-UA-Compatible:浏览器采取何种版本渲染当前页面

    1
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> //指定IE和Chrome使用最新版本渲染当前页面
  • Set-Cookie:为页面定义cookie
    如果网页过期,那么这个网页存在本地的cookies也会被自动删除。

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