How to detect the device orientation using CSS media queries?

Francesco picture Francesco · Apr 20, 2011 · Viewed 179.6k times · Source

In JavaScript the orientation mode can be detected using:

if (window.innerHeight > window.innerWidth) {
    portrait = true;
} else {
    portrait = false;
}

However, is there a way to detect the orientation using CSS only?

Eg. something like:

@media only screen and (width > height) { ... }

Answer

Richard Schneider picture Richard Schneider · Apr 20, 2011

CSS to detect screen orientation:

 @media screen and (orientation:portrait) { … }
 @media screen and (orientation:landscape) { … }

The CSS definition of a media query is at http://www.w3.org/TR/css3-mediaqueries/#orientation