下午写跳转的时候遇到了meta标签,说来惭愧,之前一直限于这一句话,赶紧乘机好好学一波。
问:meta是啥东东?(可参考英文版W3school,中文版翻译不是很好)
答:meta常用于定义页面的说明,关键字,最后修改日期,和其它的元数据。这些元数据将服务于浏览器(如何布局或重载页面),它不会显示在页面上,但是机器却可以识别。
问:meta有哪几部分组成?
答:meta标签共有两个属性,分别是http-equiv属性和name属性。
问:能举个例子吗?
答:当然!
-
name属性
name属性主要用于描述网页(比如网页的关键词,叙述等)。与之对应的属性值为content,content中的内容是对name填入类型的具体描述,便于搜索引擎抓取。meta标签中name属性语法格式是:
<meta name="参数" content="具体的描述">
其中name属性共有以下几种参数:
1)keywords :告诉搜索引擎网页的关键字<meta name="keywords" content="Java,Linux">>
2)description :告诉搜索引擎网站的主要内容。
<meta name="description" content="Java偏执狂页面介绍">
3) viewport(移动端的窗口) :常用于设计移动端网页。在用bootstrap,AmazeUI等框架时候都有用过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"> 具体参数如下:
1.none : 搜索引擎将忽略此网页,等价于noindex,nofollow。
2.noindex : 搜索引擎不索引此网页。
3.nofollow: 搜索引擎不继续通过此网页的链接索引搜索其它的网页。
4.all : 搜索引擎将索引此网页与继续通过此网页的链接索引,等价于index,follow。
5.index : 搜索引擎索引此网页。
6.follow : 搜索引擎继续通过此网页的链接索引搜索其它的网页。
5 ) author :用于标注网页作者举例:
<meta name="author" content="www.xxxxxxx@163.com">
6 ) generator(网页制作软件) 说明:用于标明网页是什么软件做的。
<meta name="generator" content="Sublime Text3">
7 )copyright(版权) 说明:用于标注版权信息举例:
<meta name="copyright" content="Lxxyx"> //代表该网站为Lxxyx个人版权所有。
8 ) revisit-after(搜索引擎爬虫重访时间)
说明:如果页面不是经常更新,为了减轻搜索引擎爬虫对服务器带来的压力,可以设置一个爬虫的重访时间。如果重访时间过短,爬虫将按它们定义的默认时间来访问。
<meta name="revisit-after" content="7 days" >
renderer是为双核浏览器准备的,用于指定双核浏览器默认以何种方式渲染页面。比如360浏览器。eg:
<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的文件头作用。(equiv的全称是"equivalent",意思是相等,相当于。)
meta标签中http-equiv属性语法格式是:
<meta http-equiv="参数" content="具体的描述">
其中http-equiv属性主要有以下几种参数:
1) content-Type(设定网页字符集)(推荐使用HTML5的方式),用于设定网页字符集,便于浏览器解析与渲染页面。
<meta http-equiv="content-Type" content="text/html;charset=utf-8"> //旧的HTML,不推荐
<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(指定请求和响应遵循的缓存机制)
用法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" />
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.baidu.com/"> //意思是2秒后跳转向百度
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"> //具体范例