The Web Design Group

meta - Metadata

Syntax <meta />
Attribute Specifications
Contents Empty
Contained in head

The meta element provides metadata such as a document's keywords, description, and author. Any number of meta elements may be contained in the head of a document.

meta's name attribute provides a property name while the content attribute gives the corresponding value. The content attribute value may contain text and entities, but it may not contain XHTML tags.

The optional scheme attribute gives the format of the property value. For example, a date property may require scheme="month-day-year" to disambiguate the date from other formats such as scheme="day-month-year".

There is no standard list of meta properties, so authors may define whatever metadata they like. The following example defines the author of the document:

<meta name="author" content="Liam Quinn" />

Some search engines use keywords and description properties, giving extra weight to a document's keywords and providing its description with the link to the document. Example:

<meta name="description" content="A description of XHTML 1.0's meta element for metadata." />
<meta name="keywords" content="meta, meta element, metadata, metainformation, meta data, meta information, keywords, description, refresh, hypertext markup language, XHTML, XHTML1, XHTML 1.0, Web Design Group, WDG, &lt;meta&gt; tag, &lt;meta&gt; tag" />

To avoid being truncated by search engines, the description should be brief--no more than 200 characters. Keywords are separated by commas and may be considered case sensitive by search engines. If the same keywords are repeated too often in the meta element, some search engines will not index the document. Search engines typically only process the first 1000 characters of the keywords list.

Some search engines also support the robots property for indicating whether a document should be indexed and whether its links should be followed. The associated content value is a comma-separated list of case-insensitive directives:

For example, the following meta element tells search engines and other robots not to index the page but to follow links on it:

<meta name="robots" content="noindex,follow" />

Few search engines support the robots property at this time. For greater compliance by robots, authors should use the Robots Exclusion Protocol if possible.

The http-equiv attribute may be used in place of the name attribute to indicate that the property is an HTTP header. Some servers will send the HTTP header specified in the meta element, and browsers often recognize the header even when it is not sent by the server. Examples:

<meta http-equiv="Expires" content="Sun, 22 Mar 1998 16:18:35 GMT" />
sets the expiry date of the document.
<meta http-equiv="Content-Script-Type" content="text/javascript" />
sets the client-side scripting language for inline scripts to JavaScript.
<meta http-equiv="Content-Style-Type" content="text/css" />
sets the style language for inline styles to CSS.
<meta http-equiv="content-type" content="text/html; charset=shift_jis" />
sets the character encoding for the document to SHIFT_JIS (a Japanese encoding). Note that using meta for this purpose rather than a true HTTP header causes some browsers to redraw the page after initially displaying it.
<meta http-equiv="Refresh" content="10; url=http://www.htmlhelp.com/" />
tells the browser to load http://www.htmlhelp.com/ 10 seconds after the current document has finished loading. Not all browsers support this, so authors should provide an alternate means of moving to the new page where necessary. The refresh header is sometimes used for "splash screens" or when a page has moved, but the technique is not very effective since users may not even be looking at the window that is to be refreshed and since it messes up the user's history on many browsers. Some search engines penalize pages that use a refresh of a few seconds or less.

More Information