meta 标签
meta 标签
参考:https://blog.csdn.net/yc123h/article/details/51356143
1. 什么是meta标签
元数据(metadata)是关于数据的信息。
标签提供关于 HTML 文档的元数据。元数据不会显示在页面上,但是对于机器是可读的。
典型的情况是,meta 元素被用于规定页面的描述、关键词、文档的作者、最后修改时间以及其他元数据。
标签始终位于 head 元素中。
元数据可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务。
其实对上面的概念简单总结下就是:<meta>
标签提供关于 HTML 文档的元数据。它不会显示在页面上,但是对于机器是可读的。可用于浏览器(如何显示内容或重新加载页面),搜索引擎(关键词),或其他 web 服务。
2. meta 的作用
meta 里的数据是供机器解读的,告诉机器该如何解析这个页面,还有一个用途是可以添加服务器发送到浏览器的 http 头部内容,例如我们为页面中添加如下 meta 标签:
<meta http-equiv="charset" content="iso-8859-1"> <meta http-equiv="expires" content="31 Dec 2008">
那么浏览器的头部就会包括这些:
charset: iso-8859-1 expires: 31 Dec 2008
3. meta的必需属性和可选属性
3.1 必需属性 content
meta 的必需属性是 content,当然并不是说 meta 标签里一定要有 content,而是当有 http-equiv 或 name 属性的时候,一定要有 content 属性对其进行说明。例如:
<meta name="keywords" content="HTML,ASP,PHP,SQL">
这里面 content 里的属性就是对 keywords 进行的说明,所以呢也可以理解成一个键值对吧,就是{keywords:"HTML,ASP,PHP,SQL"}
。
3.2 可选属性
对于 meta 的可选属性说到了三个,分别是 http-equiv、name 和 scheme 。考虑到 scheme不是很常用,所以就只说下前两个属性吧。
3.2.1 http-equiv
http-equiv
属性是添加 http 头部内容,对一些自定义的,或者需要额外添加的 http 头部内容,需要发送到浏览器中,我们就可以是使用这个属性。在上面的 meta 作用中也有简单的说明,那么现在再举个例子。例如我们不想使用 js 来重定向,用 http 头部内容控制,那么就可以这样控制:
<meta http-equiv="Refresh" content="5;url=http://www.baidu.com" />
在页面中加入这个后,5秒钟后就会跳转到指定页面。
3.2.2 name
第二个可选属性是 name,这个属性是供浏览器进行解析,对于一些浏览器兼容性问题,name 属性是最常用的,当然有个前提就是浏览器能够解析你写进去的 name 属性才可以,不然就是没有意义的。还是举个例子吧:
<meta name="renderer" content="webkit">
这个 meta 标签的意思就是告诉浏览器,用 webkit 内核进行解析,当然前提是浏览器有 webkit 内核才可以,不然就是没有意义的。当然看到这个你可能会有疑问,这个 renderer 是从哪里冒出来的,我要怎么知道呢?这个就是在对应的浏览器的开发文档里就会有表明的,例如这个 renderer 是在360浏览器里说明的。
4. 常用meta标签大总结
4.1 charset
charset 是声明文档使用的字符编码,解决乱码问题主要用的就是它,值得一提的是,这个 charset 一定要写第一行,不然就可能会产生乱码了。
charset有两种写法:
<meta charset="utf-8"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
两个都是等效的。
4.2 百度禁止转码
百度会自动对网页进行转码,这个标签是禁止百度的自动转码
<meta http-equiv="Cache-Control" content="no-siteapp" />
4.3 SEO 优化部分
<!-- 页面标题<title>标签(head 头部必须) --> <title>your title</title> <!-- 页面关键词 keywords --> <meta name="keywords" content="your keywords"> <!-- 页面描述内容 description --> <meta name="description" content="your description"> <!-- 定义网页作者 author --> <meta name="author" content="author,email address"> <!-- 定义网页搜索引擎索引方式,robotterms 是一组使用英文逗号「,」分割的值,通常有如下几种取值:none,noindex,nofollow,all,index和follow。 --> <meta name="robots" content="index,follow">
4.4 viewport
viewport主要是影响移动端页面布局的,例如:
<meta name="viewport" content="width=device-width, initial-scale=1.0">
content 参数:
- width viewport 宽度(数值/device-width)
- height viewport 高度(数值/device-height)
- initial-scale 初始缩放比例
- maximum-scale 最大缩放比例
- minimum-scale 最小缩放比例
- user-scalable 是否允许用户缩放(yes/no)
4.5 各浏览器平台
4.5.1 Microsoft Internet Explorer
<!-- 优先使用最新的ie版本 --> <meta http-equiv="x-ua-compatible" content="ie=edge"> <!-- 是否开启cleartype显示效果 --> <meta http-equiv="cleartype" content="on"> <meta name="skype_toolbar" content="skype_toolbar_parser_compatible"> <!-- Pinned Site --> <!-- IE 10 / Windows 8 --> <meta name="msapplication-TileImage" content="pinned-tile-144.png"> <meta name="msapplication-TileColor" content="#009900"> <!-- IE 11 / Windows 9.1 --> <meta name="msapplication-config" content="ieconfig.xml">
4.5.2 Google Chrome
<!-- 优先使用最新的chrome版本 --> <meta http-equiv="X-UA-Compatible" content="chrome=1" /> <!-- 禁止自动翻译 --> <meta name="google" value="notranslate">
HTML/HTTP/浏览器