Heim >Web-Frontend >js-Tutorial >Wie erkennt man mithilfe von JavaScript zuverlässig die Rotation von Android-Telefonen in Browsern?

Wie erkennt man mithilfe von JavaScript zuverlässig die Rotation von Android-Telefonen in Browsern?

Barbara Streisand
Barbara StreisandOriginal
2024-10-30 15:18:59958Durchsuche

How to Reliably Detect Android Phone Rotation in Browsers Using JavaScript?

Erkennen der Drehung von Android-Telefonen in Browsern mit JavaScript

In iOS-Browsern können Entwickler die Bildschirmdrehung mithilfe des Ereignisses onorientationchange und der Abfrage von window.orientation erkennen für den Winkel. Kann eine ähnliche Funktionalität auf Android-Smartphones erreicht werden?

Browserverhalten auf Android

Im Gegensatz zu iOS variiert das Verhalten von Bildschirmrotationsereignissen auf Android je nach Gerät. Die Ereignisse „resize“ und „orientationChange“ können in unterschiedlichen Reihenfolgen und Häufigkeiten ausgelöst werden. Darüber hinaus können sich Werte wie screen.width und window.orientation inkonsistent verhalten. Sich ausschließlich auf die Bildschirmbreite zu verlassen, ist besonders unzuverlässig, da sie sich beim Drehen in iOS nicht ändert.

Zuverlässiger Ansatz

Um diese Inkonsistenzen zu beheben, empfiehlt es sich, zuzuhören Sowohl Resize- als auch OrientationChange-Ereignisse, kombiniert mit intermittierender Abfrage. Dies gewährleistet die Erfassung gültiger Orientierungswerte auch in Szenarien, in denen Ereignisse nicht regelmäßig ausgelöst werden.

var previousOrientation = window.orientation;
var checkOrientation = function(){
    if(window.orientation !== previousOrientation){
        previousOrientation = window.orientation;
        // Handle orientation change
    }
};

window.addEventListener("resize", checkOrientation, false);
window.addEventListener("orientationchange", checkOrientation, false);

// Polling as a safety catch for 180-degree rotations
setInterval(checkOrientation, 2000);

Testergebnisse

Tests auf verschiedenen Android-Geräten ergaben erhebliche Abweichungen:

Device Events Fired Orientation InnerWidth Screen.width
iPad 2 (Landscape) Resize
OrientationChange
90 1024 768
iPad 2 (Portrait) Resize
OrientationChange
0 768 768
iPhone 4 (Landscape) Resize
OrientationChange
90 480 320
iPhone 4 (Portrait) Resize
OrientationChange
0 320 320
Droid Phone (Landscape) OrientationChange
Resize
90 320 320
Droid Phone (Portrait) OrientationChange
Resize
0 569 569
Samsung Galaxy Tablet (Landscape) OrientationChange
OrientationChange
OrientationChange
Resize
90 400 400
Samsung Galaxy Tablet (Portrait) OrientationChange
OrientationChange
OrientationChange
Resize
0 683 683

Das obige ist der detaillierte Inhalt vonWie erkennt man mithilfe von JavaScript zuverlässig die Rotation von Android-Telefonen in Browsern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn