The HTML <meta> element represents metadata that cannot be represented by other HTML meta-related elements, like <base>, <link>, <script>, <style> or <title>.
| Content categories | Metadata content. If the itemprop attribute is present: flow content, phrasing content. |
|---|---|
| Permitted content | None, it is an empty element. |
| Tag omission | As it is a void element, the start tag must be present and the end tag must not be present. |
| Permitted parents | <meta charset>, <meta http-equiv>: a <head> element. If the http-equiv is not an encoding declaration, it can also be inside a <noscript> element, itself inside a <head> element. |
| Permitted ARIA roles | None |
| DOM interface | HTMLMetaElement |
Attributes
This element includes the global attributes.
Note: the global attribute name has a specific meaning for the <meta> element, and the itemprop attribute must not be set on the same <meta> element that has any existing name, http-equiv or charset attributes.
charset- This attribute declares the page's character encoding. It must contain a standard IANA MIME name for character encodings. Although the standard doesn't request a specific encoding, it suggests:
- Authors are encouraged to use
UTF-8. - Authors should not use ASCII-incompatible encodings to avoid security risk: browsers not supporting them may interpret harmful content as HTML. This happens with the
JIS_C6226-1983,JIS_X0212-1990,HZ-GB-2312,JOHAB, the ISO-2022 family and the EBCDIC family.
Note: ASCII-incompatible encodings are those that don't map the 8-bit code points
0x20to0x7Eto the0x0020to0x007EUnicode code points)- Authors must not use
CESU-8,UTF-7,BOCU-1and/orSCSUas cross-site scripting attacks with these encodings have been demonstrated. - Authors should not use
UTF-32because not all HTML5 encoding algorithms can distinguish it fromUTF-16.
Notes:- The declared character encoding must match the one the page was saved with to avoid garbled characters and security holes.
- The
<meta>element declaring the encoding must be inside the<head>element and within the first 1024 bytes of the HTML as some browsers only look at those bytes before choosing an encoding. - This
<meta>element is only one part of the algorithm to determine a page's character set. TheContent-Typeheader and any Byte-Order Marks override this element. - It is strongly recommended to define the character encoding. If a page's encoding is undefined, cross-scripting techniques are possible, such as the
UTF-7fallback cross-scripting technique. - The
<meta>element with acharsetattribute is a synonym for the pre-HTML5<meta http-equiv="Content-Type" content="text/html; charset=IANAcharset">, whereIANAcharsetcontains the value of the equivalentcharsetattribute. This syntax is still allowed, although no longer recommended.
- Authors are encouraged to use
content- This attribute contains the value for the
http-equivornameattribute, depending on which is used. http-equiv- This attribute can contain the name of a HTTP header, hence the attribute name
http-equiv(alent). It defines an instruction that can alter server and user-agent behaviour. The value of the instruction is defined inside thecontentattribute, and can be one of the following:"content-language"
Defines the default language of the page. It can be overridden by the lang attribute on any element.
Warning: Do not use this value, as it is obsolete. Prefer the
langattribute on the<html>element."content-security-policy"
Allows page authors to define a content policy for the current page. Content policies mostly specify allowed server origins and script endpoints which help guard against cross-site scripting attacks."content-type"
Defines the MIME type of the document, followed by its character encoding. It follows the same syntax as the HTTPcontent-typeentity-header field, but as it is inside a HTML page, most values other thantext/htmlare impossible. Therefore the valid syntax for itscontentis the string 'text/html' followed by a character set with the following syntax: '; charset=IANAcharset', whereIANAcharsetis the preferred MIME name for a character set as defined by the IANA.
"refresh"
This instruction specifies:"set-cookie"
Defines a cookie for the page. Its content must follow the syntax defined in the IETF HTTP Cookie Specification.
Warning: Do not use this instruction, as it is obsolete. Use the HTTP header
Set-Cookieinstead.-
Note: As
<meta>can't change documents' types in XHTML or HTML5's XHTML serialization, never set the MIME type to an XHTML MIME type with<meta>.
name-
This attribute defines the name of a piece of document-level metadata. It should not be set if one of the attributes
itemprop,http-equivorcharsetis also set.This metadata name is associated with the value contained by the
contentattribute. The possible values for the name attribute are:application-namewhich defines the name of the application running in the web page.Note:- Browsers may use this to identify the application. It is different from the
<title>element, which usually contain the application name, but may also contain information like the document name or a status. - Simple web pages shouldn't define an application-name.
- Browsers may use this to identify the application. It is different from the
authorwhich defines the name of the document's author.descriptionwhich contains a short and accurate summary of the content of the page. Several browsers, like Firefox and Opera, use this as the default description of bookmarked pages.generatorwhich contains the identifier of the software that generated the page.keywordswhich contains words relevant to the page's content separated by commas.referrerwhich controls theRefererHTTP header attached to requests sent from the document:Values for the contentattribute of<meta name="referrer">no-referrerDo not send a HTTP Refererheader.originSend the origin of the document. no-referrer-when-downgradeSend the origin as a referrer to URLs as secure as the current page, (https→https), but does not send a referrer to less secure URLs (https→http). This is the default behaviour. origin-when-crossoriginSend the full URL (stripped of parameters) for same-origin requests, but only send the origin for other cases. unsafe-URLSend the full URL (stripped of parameters) for same-origin or cross-origin requests. Notes:
- Some browsers support the deprecated values of
always,default, andneverfor referrer. - Dynamically inserting
<meta name="referrer">(withdocument.writeorappendChild) makes the referrer behaviour unpredictable. - When several conflicting policies are defined, the no-referrer policy is applied.
- Some browsers support the deprecated values of
This attribute may also have a value taken from the extended list defined on WHATWG Wiki MetaExtensions page. Although none have been formally accepted yet, a few commonly used names are:
creatorwhich defines the name of the creator of the document, such as an organization or institution. If there are more than one, several<meta>elements should be used.googlebot, a synonym ofrobots, is only followed by Googlebot (the indexing crawler for Google).publisherwhich defines the name of the document's publisher.robotswhich defines the behaviour that cooperative crawlers, or "robots", should use with the page. It is a comma-separated list of the values below:Values for the content of <meta name="robots">Value Description Used by indexAllows the robot to index the page (default). All noindexRequests the robot to not index the page. All followAllows the robot to follow the links on the page (default). All nofollowRequests the robot to not follow the links on the page. All noneEquivalent to noindex, nofollowGoogle noodpPrevents using the Open Directory Project description, if any, as the page description in search engine results. noarchiveRequests the search engine not to cache the page content. Google, Yahoo, Bing nosnippetPrevents displaying any description of the page in search engine results. Google, Bing noimageindexRequests this page not to appear as the referring page of an indexed image. Google nocacheSynonym of noarchive.Bing Notes:- Only cooperative robots follow these rules. Do not expect to prevent e-mail harvesters with them.
- The robot still needs to access the page in order to read these rules. To prevent bandwidth consumption, use a robots.txt file.
- If you want to remove a page,
noindexwill work, but only after the robot visits the page again. Ensure that therobots.txtfile is not preventing revisits. - Some values are mutually exclusive, like
indexandnoindex, orfollowandnofollow. In these cases the robot's behaviour is undefined and may vary between them. - Some crawler robots, like Google, Yahoo and Bing, support the same values for the HTTP header
X-Robot-Tags; this allows non-HTML documents like images to use these rules.
slurp, is a synonym ofrobots, but only for Slurp - the crawler for Yahoo Search.viewport, which gives hints about the size of the initial size of the viewport. Used by mobile devices only.Values for the content of <meta name="viewport">Value Possible subvalues Description widthA positive integer number, or the text device-widthDefines the pixel width of the viewport that you want the web site to be rendered at. heightA positive integer, or the text device-heightDefines the height of the viewport. Not used by any browser. initial-scaleA positive number between 0.0and10.0Defines the ratio between the device width ( device-widthin portrait mode ordevice-heightin landscape mode) and the viewport size.maximum-scaleA positive number between 0.0and10.0Defines the maximum amount to zoom in. It must be greater or equal to the minimum-scaleor the behaviour is undefined. Browser settings can ignore this rule and iOS10+ ignores it by default.minimum-scaleA positive number between 0.0and10.0Defines the minimum zoom level. It must be smaller or equal to the maximum-scaleor the behaviour is undefined. Browser settings can ignore this rule and iOS10+ ignores it by default.user-scalableyesornoIf set to no, the user is not able to zoom in the webpage. The default isyes. Browser settings can ignore this rule, and iOS10+ ignores it by default.Specification Status Comment CSS Device Adaptation
The definition of '<meta name="viewport">' in that specification.Working Draft Non-normatively describes the Viewport META element See also:@viewportNotes:- Though unstandardized, this declaration is respected by most mobile browsers due to de-facto dominance.
- The default values may vary between devices and browsers.
- To learn about this declaration in Firefox for Mobile, see this article.
scheme- This attribute defines the scheme in which metadata is described. A scheme is a context leading to the correct interpretations of the
contentvalue, like a format.
Warning: Do not use this value, as it is obsolete. There is no replacement as there was no real usage for it.
Notes
Depending on the attributes set, the kind of metadata can be one of the following:
- If
nameis set, it is document-level metadata, applying to the whole page. - If
http-equivis set, it is a pragma directive — information normally given by the web server about how the web page is served. - If
charsetis set, it is a charset declaration — the character encoding used by the webpage. - If
itempropis set, it is user-defined metadata — transparent for the user-agent as the semantics of the metadata is user-specific.
Examples
<meta charset="utf-8"> <!-- Redirect page after 3 seconds --> <meta http-equiv="refresh" content="3;url=https://www.mozilla.org">
Specifications
| Specification | Status | Comment |
|---|---|---|
| Referrer Policy The definition of '<meta name="referrer">' in that specification. |
Editor's Draft | Defines values and semantics of <meta name="referrer">. |
| HTML Living Standard The definition of '<meta>' in that specification. |
Living Standard | Added itemprop attribute |
| HTML5 The definition of '<meta>' in that specification. |
Recommendation | Added charset attribute |
| HTML 4.01 Specification The definition of '<meta>' in that specification. |
Recommendation |
Browser compatibility
The information shown below has been pulled from MDN's Github (https://github.com/mdn/browser-compat-data).
The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
| Feature | Chrome | Edge | Firefox | Internet Explorer | Opera | Safari |
|---|---|---|---|---|---|---|
| Basic support | Yes | Yes | 1 | Yes | Yes | Yes |
charset | Yes | Yes | 1 | Yes | Yes | Yes |
content | Yes | Yes | 1 | Yes | Yes | Yes |
http-equiv | Yes | Yes | 1 | Yes | Yes | Yes |
name | Yes | Yes | 1 | Yes | Yes | Yes |
| Feature | Android webview | Chrome for Android | Edge mobile | Firefox for Android | IE mobile | Opera Android | iOS Safari |
|---|---|---|---|---|---|---|---|
| Basic support | Yes | Yes | Yes | 4 | Yes | Yes | Yes |
charset | Yes | Yes | Yes | 4 | Yes | Yes | Yes |
content | Yes | Yes | Yes | 4 | Yes | Yes | Yes |
http-equiv | Yes | Yes | Yes | 4 | Yes | Yes | Yes |
name | Yes | Yes | Yes | 4 | Yes | Yes | Yes |

