I\'m experiencing this problem on an iPhone device (iPhone 7, iOS 10, but also other iPhones too): in javascript, if I intercept the orientationchange event, inside the handler,
As far as I know screen the width/height will not change in the device after rotation. To check if the device is rotated you could read these properties
Unfortunately, this behavior is not consistent across all Android/iOS/Window devices. I think it's pretty explained in this figure .
jQuery mobile has onOrienntetionChange event that handle orientation changing event,and there is $(window).orientationchange();
function to change orientation manually.
iOS used to return the size of the screen as if it was in portrait. They changed it on iOS 8 (on the native classes), but they might have forgotten to do it for Safari, or maybe they kept it that way for compatibility.
If you want the real size based on the orientation you can use
window.innerWidth
and window.innerHeight
I get the same values with or without the viewport meta tag
It works fine on Chrome simulated visualization because it return the screen size of the simulated visualization, as it should be, but it doesn't simulate the OS where it should be running based on the device, so you won't get the same values as on a real device (in this case in which the real device doesn't return good values)
CSS can't detect the orientation change.
Use JavaScript to get the orientation change.
Add the function as
window.addEventListener("orientationchange", function() {
document.body.style.width = window.innerWidth;
});
This will add an event Handler
to window
to change the width
of body
when the orientation is changed.
More reference on orientationchange