How to fix: The frameborder attribute on the iframe element is obsolete. Use CSS instead.

Most Likely Cause and Fix

Your HTML5 markup contains an <iframe> element with a frameborder attribute in the form:

<iframe frameborder="0" … />

This attribute is no longer present in HTML5. Use CSS instead:

<iframe style="border:0;" … />

Or consider the HTML5 seamless attribute.

See also: HTML5 and frameborder on Stack Overflow.

What This Error Means

There are three aspects to a web-based document:

  • Structure: the underlying arrangement of the document and the elements contained within; handled by HTML

  • Presentation: how elements look and where on the page they're placed; handled by CSS.

  • Behaviour: how the elements respond when being interacted with; handled by JavaScript (in general)

The appearance of and placement text and other page elements is a presentational matter and as such is best implemented at the presentational layer and handled by CSS.

HTML5 follows this approach and removes various presentational attributes previously specified on elements in markup in preference of CSS rules that can achieve the equivalent effect.

This error is letting you know that you have presentational markup in your HTML that is no longer valid and that you should instead remove such attributes and apply relevant CSS rules.

How To Fix It

For iframe elements in HTML5 documents

HTML5 no longer allows the frameborder attribute on an <iframe> element:

<iframe frameborder="0" … />

You should use CSS instead to achieve the same effect:

<iframe style="border:0;" … />

Or consider the HTML5 seamless attribute.

See also: HTML5 and frameborder on Stack Overflow.

Discuss, Comment and Improve

Did this help you? Can this page be improved? Let us know!

comments powered by Disqus