Beibehalten der Größe fester Elemente beim Touchscreen-Zoomen
Mit Touchscreens ausgestattete Mobilgeräte stellen eine einzigartige Herausforderung für feste Elemente auf Webseiten dar. Wenn Benutzer den Bildschirm zusammenziehen, um hineinzuzoomen, neigen feste Elemente dazu, ihre Größe zusammen mit dem Rest des Inhalts zu ändern, wodurch möglicherweise darunter liegende Elemente verdeckt werden.
Um dieses Verhalten zu verhindern, können wir eine Technik verwenden, die den aktuellen Zoomfaktor berechnet und wendet eine entsprechende CSS3-Transformation auf das feste Element an und stellt sicher, dass es jederzeit die gleiche Größe behält.
<code class="javascript">window.addEventListener('scroll', function(e) { var zoom = window.innerWidth / document.documentElement.clientWidth; el.style["transform"] = "scale(" + zoom + ")"; });</code>
Diese Logik berechnet den Zoomfaktor und wendet ihn als Skalierungstransformation an. Da die Position des festen Elements jedoch möglicherweise ungenau wird, passen wir sie mithilfe der absoluten Positionierung an:
<code class="javascript">el.style.left = window.pageXOffset + 'px'; el.style.bottom = document.documentElement.clientHeight - (window.pageYOffset + window.innerHeight) + 'px';</code>
Die Positionierung des festen Elements innerhalb eines übergeordneten Elements mit 100 % Inhaltshöhe und die Anpassung seiner Position basierend auf den Abmessungen des Ansichtsfensters stellen sicher, dass es bleibt an der gewünschten Stelle sichtbar, unabhängig von der Zoomstufe.
Achten Sie auf die Eigenschaft transform-origin, wenn Sie den Skalierungsankerpunkt für das feste Element steuern müssen. Durch den Einsatz dieser Technik können Sie Elemente erstellen, die ihre Größe bei Touchscreen-Zoomereignissen beibehalten und so das Benutzererlebnis auf Mobilgeräten verbessern.
Das obige ist der detaillierte Inhalt vonWie kann verhindert werden, dass sich die Größe fester Elemente während des Touchscreen-Zooms ändert?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!