在查阅w3school中,第一句话中的“元数据”就让我开始了google之旅。然后很顺利的在英文版的w3school找到了想要的结果。
the tag provides metadata about the html document. metadata will not be displayed on the page, but will be machine parsable.
不难看出,其中的关键是metadata,中文名叫元数据,是用于描述数据的数据。它不会显示在页面上,但是机器却可以识别。这么一来meta标签的作用方式就很好理解了。
组成
meta标签共有两个属性,分别是http-equiv属性和name属性。
1、name属性
name属性主要用于描述网页,比如网页的关键词,叙述等。与之对应的属性值为content,content中的内容是对name填入类型的具体描述,便于搜索引擎抓取。meta标签中name属性语法格式是:
其中name属性共有以下几种参数。(a-c为常用属性)
a. keywords(关键字)
说明:用于告诉搜索引擎,你网页的关键字。举例:
b. description(网站内容的描述)
说明:用于告诉搜索引擎,你网站的主要内容。举例:
c. viewport(移动端的窗口)
说明:这个概念较为复杂,具体的会在下篇博文中讲述。这个属性常用于设计移动端网页。在用bootstrap,amazeui等框架时候都有用过viewport。
举例(常用范例):
d. robots(定义搜索引擎爬虫的索引方式)
说明:robots用来告诉爬虫哪些页面需要索引,哪些页面不需要索引。content的参数有all,none,index,noindex,follow,nofollow。默认是all。
举例:
具体参数如下:
-
none : 搜索引擎将忽略此网页,等价于noindex,nofollow。
-
noindex : 搜索引擎不索引此网页。
-
nofollow: 搜索引擎不继续通过此网页的链接索引搜索其它的网页。
-
all : 搜索引擎将索引此网页与继续通过此网页的链接索引,等价于index,follow。
-
index : 搜索引擎索引此网页。
-
follow : 搜索引擎继续通过此网页的链接索引搜索其它的网页。
e. author(作者)
说明:用于标注网页作者举例:
f. generator(网页制作软件)
说明:用于标明网页是什么软件做的举例: (不知道能不能这样写):
g. d88尊龙官网手机app copyright(kb88凯时官网登录的版权)
说明:用于标注kb88凯时官网登录的版权信息举例:
//代表该网站为lxxyx个人kb88凯时官网登录的版权所有。
h. revisit-after(搜索引擎爬虫重访时间)
说明:如果页面不是经常更新,为了减轻搜索引擎爬虫对带来的压力,可以设置一个爬虫的重访时间。如果重访时间过短,爬虫将按它们定义的默认时间来访问。举例:
i. renderer(双核浏览器渲染方式)
说明:renderer是为双核浏览器准备的,用于指定双核浏览器默认以何种方式渲染页面。比如说360浏览器。举例:
//默认webkit内核 //默认ie兼容模式 //默认ie标准模式
2、http-equiv属性
介绍之前,先说个小插曲。看文档和博客关于http-equiv的介绍时,有这么一句。
http-equiv顾名思义,相当于http的文件头作用。
meta标签中http-equiv属性语法格式是:
其中http-equiv属性主要有以下几种参数:
a. content-type(设定网页字符集)(推荐使用html5的方式)
说明:用于设定网页字符集,便于浏览器解析与渲染页面举例:
//旧的html,不推荐 //html5设定网页字符集的方式,推荐使用utf-8
b. x-ua-compatible(浏览器采取何种版本渲染当前页面)
说明:用于告知浏览器以何种版本来渲染页面。(一般都设置为最新模式,在各大框架中这个设置也很常见。)举例:
//指定ie和chrome使用最新版本渲染当前页面
c. cache-control(指定请求和响应遵循的缓存机制)
用法1.
说明:指导浏览器如何缓存某个响应以及缓存多长时间。这一段内容我在网上找了很久,但都没有找到满意的。最后终于在google developers中发现了我想要的答案。
举例:
共有以下几种用法:
-
no-cache: 先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存。
-
no-store: 不允许缓存,每次都要去服务器上,下载完整的响应。(安全措施)
-
public : 缓存所有响应,但并非必须。因为max-age也可以做到相同效果
-
private : 只为单个用户缓存,因此不允许任何中继进行缓存。(比如说cdn就不允许缓存private的响应)
-
maxage : 表示当前请求开始,该响应在多久内能被缓存和重用,而不去服务器重新请求。例如:max-age=60表示响应可以再缓存和重用 60 秒。
用法2.(禁止百度自动转码)
说明:用于禁止当前页面在移动端浏览时,被百度自动转码。虽然百度的本意是好的,但是转码效果很多时候却不尽人意。所以可以在head中加入例子中的那句话,就可以避免百度自动转码了。举例:
d. expires(网页到期时间)
说明:用于设定网页的到期时间,过期后网页必须到服务器上重新传输。举例:
e. refresh(自动刷新并指向某页面)
说明:网页将在设定的时间内,自动刷新并调向设定的网址。举例:
//意思是2秒后跳转向我的博客
f. set-cookie(cookie设定)
说明:如果网页过期。那么这个网页存在本地的cookies也会被自动删除。
//格式 //具体范例
原文地址:https://segmentfault.com/a/1190000004279791