How to fix: The width attribute on the th element is obsolete. Use CSS instead.

Most Likely Cause and Fix

Your HTML5 markup contains an <th> element with a width attribute in the form:

<table width="100%">
  <tr>
    <th width="80%">Foo</td>
    <th width="20%">Bar</td>
  </tr>
</table>

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

<table style="width:100%;">
  <tr>
    <th style="width:80%;">Foo</td>
    <th style="width:20%;">Bar</td>
  </tr>
</table>

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 table cells and the wisth attribute

HTML5 no longer allows the width attribute on an <th> element:

<table width="100%">
  <tr>
    <th width="80%">Foo</td>
    <th width="20%">Bar</td>
  </tr>
</table>

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

<table style="width:100%;">
  <tr>
    <th style="width:80%;">Foo</td>
    <th style="width:20%;">Bar</td>
  </tr>
</table>

Discuss, Comment and Improve

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

comments powered by Disqus