|
# ?' a. F6 a& w6 ~1 x
打开任意的网站,其head标签内都有一列的meta标签 $ R# U* F0 d! L1 L" R, `, q- _9 B
一、简介英文版W3school的解释The tag provides metadata about the HTML document. Metadata will not be. M& v# c; M. \
displayed on the page, but will be machine parsable.
/ {/ ?! h" z: O 其中的关键是metadata,中文名叫元数据,是用于描述数据的数据它不会显示在页面上,但是机器却可以识别这么一来meta标签的作用方式就很好理解了二、用处Meta elements are typically used to specify page description, keywords, author
- M- C5 `- m- y) ]) b% W4 w' y of the document,last modified, and other metadata.。
3 c- E6 @2 I( R) Q# |) Z! Y The metadata can be used by browsers (how to display content or reload page), search engines (keywords), or other web services 3 G' X' Y/ z, P I
翻译过来就是:meta常用于定义页面的说明,关键字,最后修改日期,和其它的元数据这些元数据将服务于浏览器(如何布局或重载页面),搜索引擎和其它网络服务三、组成meta标签共有两个属性,分别是http-equiv。
5 l; e ?( S, G& t3 J( A 属性和name属性3.1 name属性name属性主要用于描述网页,比如网页的关键词,叙述等与之对应的属性值为content,content中的内容是对name填入类型的具体描述,便于搜索引擎抓取meta标签中name属性语法格式是: 9 t8 S# {4 N" _0 E$ z% ^
其中name属性共有以下几种参数(A-C为常用属性)A. keywords(关键字)说明:用于告诉搜索引擎,你网页的关键字举例:。 % Q9 C4 X! T" u) q5 l% B
B. description(网站内容的描述)说明:用于告诉搜索引擎,你网站的主要内容举例:。
& W! r3 o a. h# P8 A C. viewport(移动端的窗口)这个属性常用于设计移动端网页在用bootstrap,AmazeUI等框架时候都有用过viewport举例(常用范例):。
" Y8 f2 Z' P1 D2 H# z+ y: j- } D. robots(定义搜索引擎爬虫的索引方式)说明:robots用来告诉爬虫哪些页面需要索引,哪些页面不需要索引content的参数有all,none,index,noindex,follow,nofollow。 . t2 `- {8 n9 o) ]
默认是all举例:具体参数如下:1.none : 搜索引擎将忽略此网页,等价于noindex,nofollow2.noindex : 搜索引擎不索引此网页。 , `- i. F8 S: X: t/ C/ [* \: d9 F5 L' l, \
3.nofollow: 搜索引擎不继续通过此网页的链接索引搜索其它的网页4.all : 搜索引擎将索引此网页与继续通过此网页的链接索引,等价于index,follow5.index : 搜索引擎索引此网页。
& }3 x9 q+ }$ x9 M- ?: Q, Q8 _% q 6.follow : 搜索引擎继续通过此网页的链接索引搜索其它的网页E. author(作者)说明:用于标注网页作者举例:。 : T0 q- y% u# \9 G+ c( @; N
F. generator(网页制作软件)说明:用于标明网页是什么软件做的举例: (不知道能不能这样写):G. copyright(版权)
3 S" f4 |7 p" I4 y 说明:用于标注版权信息举例: //代表该网站为Lxxyx个人版权所有H. revisit-after(搜索引擎爬虫重访时间)。 ; p2 c( N% F* i: Q2 ~
说明:如果页面不是经常更新,为了减轻搜索引擎爬虫对服务器带来的压力,可以设置一个爬虫的重访时间如果重访时间过短,爬虫将按它们定义的默认时间来访问举例:。 / [7 |- t6 r! m! z# u9 g S" W$ {
I. renderer(双核浏览器渲染方式)说明:renderer是为双核浏览器准备的,用于指定双核浏览器默认以何种方式渲染页面比如说360浏览器举例: //默认webkit内核' w# I, Q8 U6 D5 B: y
//默认IE兼容模式9 e- v# `; x3 @3 z2 j L
//默认IE标准模式。
8 p0 P( [% u% H* b* w1 W H4 ` 3.2 http-equiv属性http-equiv顾名思义,相当于http的文件头作用这个我所认为的http-equiv意思的简介:相当于HTTP的作用,比如说定义些HTTP参数啥的meta标签中http-equiv属性语法格式是:。 % w7 n, B. ^/ z5 H9 q$ F& I
其中http-equiv属性主要有以下几种参数:A. content-Type(设定网页字符集)(推荐使用HTML5的方式)说明:用于设定网页字符集,便于浏览器解析与渲染页面
8 ?/ q8 t n9 T/ C( m; L 举例: //旧的HTML,不推荐
7 G7 \$ q7 y% ~ o! ~! \6 n9 h5 p; b* |! L
//HTML5设定网页字符集的方式,推荐使用UTF-8
6 X" |+ u1 c Q B. X-UA-Compatible(浏览器采取何种版本渲染当前页面)说明:用于告知浏览器以何种版本来渲染页面(一般都设置为最新模式,在各大框架中这个设置也很常见)举例: //指定IE和Chrome使用最新版本渲染当前页面。 % c8 _" T) Q( h& {6 b, C- ]
C. cache-control(指定请求和响应遵循的缓存机制)用法1.说明:指导浏览器如何缓存某个响应以及缓存多长时间举例:。
. \. v- \, Z) C) F! x2 C" @ 共有以下几种用法:no-cache: 先发送请求,与服务器确认该资源是否被更改,如果未被更改,则使用缓存no-store: 不允许缓存,每次都要去服务器上,下载完整的响应(安全措施)public : 缓存所有响应,但并非必须。
, S2 _" q6 \9 g& { 因为max-age也可以做到相同效果private : 只为单个用户缓存,因此不允许任何中继进行缓存(比如说CDN就不允许缓存private的响应)maxage : 表示当前请求开始,该响应在多久内能被缓存和重用,而不去服务器重新请求。 _8 E$ q5 N/ t4 ^1 A; G
例如:max-age=60表示响应可以再缓存和重用 60 秒参考链接:HTTP缓存link.juejin.im/?target=https%3A%2F%2Fdevelopers.google.com%2Fweb%2Ffundamentals%2Fperformance%2Foptimizing-content-efficiency%2Fhttp-caching%3Fhl%3Dzh-cn%23cache-control
# e% _" w' B- V& i, _4 ^( n$ u 用法2.(禁止百度自动转码)说明:用于禁止当前页面在移动端浏览时,被百度自动转码虽然百度的本意是好的,但是转码效果很多时候却不尽人意所以可以在head中加入例子中的那句话,就可以避免百度自动转码了举例: 6 k0 } E* n/ n! j5 ^8 A; E
D. expires(网页到期时间)说明:用于设定网页的到期时间,过期后网页必须到服务器上重新传输。 " }/ f6 A$ p5 q
举例:E. refresh(自动刷新并指向某页面)说明:网页将在设定的时间内,自动刷新并调向设定的网址。
3 b2 J7 X0 [6 ?, U5 B4 N# v: J9 Y+ h 举例: //意思是2秒后跳转向我的博客F. Set-Cookie(cookie设定)
l3 N8 n* Y8 ]- r2 H% N 说明:如果网页过期那么这个网页存在本地的cookies也会被自动删除 //格式+ Y! @" P k2 T1 \+ i `! q9 ~
, P5 U1 r2 p' s: S2 R3 z& J. ~# V; o" B' c6 J
//具体范例。
: m' T" o; ~" M1 S! r- X! A 参考:关于 HTML 中 meta 标签的理解和总结 + l& h4 y( E+ O J: `9 R0 H
- l9 k* X5 `0 m
, R$ |; `& a4 e- x' x @" Y9 L- h$ b
8 Q' F2 [ W' d8 C( F; u$ @( S5 `; M4 i# m7 `8 ]) ?4 g6 a3 ]) m
|