前言:至今没有好好地去搜索和梳理关于meta
标签的相关知识点,今天周会分享中,突然听到meta
可以影响这个网页的很多功能,于是好奇的搜了一下相关资料,并做记录,以供日后查证和学习。
认识meta
meta
的定义
The <meta> tag provides metadata about the HTML document. Metadata will not be displayed on the page, but will be machine parsable.
metadata又叫元数据,是描述数据的数据。根据w3c的解释<meta>
是描述HTML的元数据,<meta>
标签中的内容并不会在页面上显示,但是能被浏览器等解析。
meta
的用途
Meta elements are typically used to specify page description, keywords, author of the document, last modified, and other metadata.
meta
常用于定义页面的说明,关键字,最后修改的日期和其他元数据。这些数据将服务于浏览器如何布局或重载页面,搜索引擎或其他网络服务。
meta
的组成
meta标签共有两个属性,分别是name属性和http-equiv属性。
name属性
name属性是用来描述网页,比如网页的关键词,叙述等。与之相对应的属性为content。content中的内容是对name填入类型的具体描述,便于搜索引擎的抓取。meta标签中name属性语法格式是:
<meta name="参数" content="具体的描述">
name属性共有如下参数:keywords、description、viewport、robots、author、generator、revisit-after、renderer
1.keywords (关键词)
用于告诉搜索引擎,你的网页的关键字。
<meta name="keywords" content="企业飞信">
2.decription (网站内容的描述)
用于告诉搜索引擎,你网站的主要内容。
<meta name="decription" content="企业飞信官网">
3.viewport (移动端窗口)
具体概念及应用参见《认识viewport》一文
<meta name="viewport" content="width=device-width, initial-scale=1">
4.robots (定义搜索引擎爬虫的索引方式)
robots用来告诉爬虫哪些页面需要索引,哪些页面不需要索引。content的参数有all,none,index,noindex,follow,nofollow;默认值为all。
<meta name="robots" content="none">
具体参数含义如下:
none: 搜索引擎将忽略此网页,等价于noindex、nofollow。
noindex:搜索引擎不索引此网页。
nofollow:搜索引擎不继续通过此网页的链接索引搜索其他的网页。
all:搜索引擎将索引此网页与继续通过此网页的链接索引,等价于index、follow。
index:搜索引擎索引此网页。
follow:搜索引擎继续通过此网页的连接索引搜索其他的网页。
5.author (作者)
用于标注网页的作者。
<meta name="author" content="Lxxyx,841380530@qq.com">
6.generator (网页制作软件)
7.copyright (版权)
<meta name="copyright" content="xyx"> //代表该网站为xyx版权所有。
8.revisit-after (搜索引擎爬虫重访时间)
如果页面并不经常更新,为了减轻搜索引擎爬虫对服务器带来的压力,可以设置一个爬虫的重访时间。如果重访时间过短,爬虫将按他们定义的默认时间来访问。
<meta name="revisit-after" content="7 days" >
9.renderer (双核浏览器渲染方式)
renderer是为双核浏览器准备的,用于指定双核浏览器默认以何种方式渲染页面。比如说360浏览器。
<meta name="renderer" content="webkit"> //默认webkit内核
<meta name="renderer" content="ie-comp"> //默认IE兼容模式
<meta name="renderer" content="ie-stand"> //默认IE标准模式
http-equiv属性
http-equiv相当于http的文件头作用
主要用于定义一些http的参数。meta标签中name属性语法格式是:
<meta http-equiv="参数" content="具体的描述">
其中http-equiv属性主要有以下几种参数:
1.content-Type(设定网页字符集)(推荐使用HTML5的方式)
用于设定网页字符集,便于浏览器解析与渲染页面。
<meta charset="utf-8"> //HTML5设定网页字符集的方式,推荐使用UTF-8
2.X-UA-Compatible(浏览器采取何种版本渲染当前页面)
用于告知浏览器以何种版本来渲染页面。(一般都设置为最新模式,在各大框架中这个设置也很常见。)
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"/>//指定IE和Chrome使用最新版本渲染当前页面
3.cache-control(指定请求和响应遵循的缓存机制)
指导浏览器如何缓存某个响应以及缓存多长时间。
用法一:指导浏览器如何缓存某个响应及缓存多长时间。
<meta http-equiv="cache-control" content="no-cache">
机制和原理参见下图:
具体参数含义如下:
no-cache:先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存
no-store:不允许缓存,每次都要去服务器上,下载完整的响应。(安全措施)
public:缓存所有响应,但并非必须。因为max-age也可以做到相同效果
private:只为单个用户缓存,因此不允许任何中继进行缓存。(比如说CDN就不允许缓存private的响应)
maxage:表示当前请求开始,该响应在多久内能被缓存和重用,而不去服务器重新请求。例如:max-age=60表示响应可以再缓存和重用 60 秒。
用法二:禁止百度转码
用于当前页面在移动端浏览的时候,被百度自动转码。
<meta http-equiv="Cache-Control" content="no-siteapp" />
4.expires (网页到期时间)
用于设定网页的到期时间,过期后网页必须到服务器上重新传输。
<meta http-equiv="expires" content="Sunday 26 October 2016 01:00 GMT" />
5.refresh (自动刷新并指向某页面)
网页将在设定的时间内,自动刷新并调向设定的网址。
<meta http-equiv="refresh" content="2;URL=http://www.lxxyx.win/"> //意思是2秒后跳转向http://www.lxxyx.win
6.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"> //具体范例
引用文章: