Rumah > hujung hadapan web > tutorial css > Bagaimana untuk Menghalang Saiz Semula Elemen Tetap Semasa Mengezum Skrin Sentuh?

Bagaimana untuk Menghalang Saiz Semula Elemen Tetap Semasa Mengezum Skrin Sentuh?

DDD
Lepaskan: 2024-10-30 16:53:02
asal
329 orang telah melayarinya

How to Prevent Fixed Element Resizing During Touchscreen Zooming?

Cara Menyelesaikan Isu Saiz Semula Elemen Tetap Apabila Mengezum pada Peranti Skrin Sentuh

Dalam pembangunan web, adalah penting untuk mengekalkan konsistensi elemen tanpa mengira interaksi pengguna. Walau bagaimanapun, apabila menggunakan elemen tetap pada skrin sentuh, zum boleh menyebabkan isu saiz semula yang tidak dijangka.

Pertimbangkan coretan kod ini:

<code class="html"><div id="fixed">
  <p>Some content</p>
</div></code>
Salin selepas log masuk
<code class="css">#fixed {
  height: 150px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10000;
}</code>
Salin selepas log masuk

Pada skrin sentuh, apabila pengguna mencubit untuk mengezum masuk , elemen tetap, bersama-sama dengan kandungan yang lain, meningkat. Walau bagaimanapun, dengan zum yang berlebihan, elemen boleh menjadi bersaiz besar dan bertindih dengan kandungan lain. Untuk menangani isu ini, kami perlu menghalang elemen tetap kami daripada mengubah saiz semasa acara zum.

Penyelesaian terletak pada pengiraan semula skala dan kedudukan elemen berdasarkan tahap zum pengguna. Kita boleh mencapainya dengan terus mengemas kini perubahan dan kedudukan CSS elemen semasa acara tatal:

<code class="javascript">window.addEventListener('scroll', function(e) {
  // Calculate the zoom factor.
  var zoom = window.innerWidth / document.documentElement.clientWidth;

  // Apply the zoom factor as a CSS3 transform.
  el.style["transform"] = "scale(" + zoom + ")";
});</code>
Salin selepas log masuk
<code class="javascript">// Reset the element's position.
el.style.left = window.pageXOffset + 'px';
el.style.bottom = document.documentElement.clientHeight - (window.pageYOffset + window.innerHeight) + 'px';</code>
Salin selepas log masuk

Pendekatan ini secara berkesan menskalakan elemen kembali kepada saiz asalnya dan melaraskan kedudukannya dengan sewajarnya, tanpa mengira zum tahap.

Atas ialah kandungan terperinci Bagaimana untuk Menghalang Saiz Semula Elemen Tetap Semasa Mengezum Skrin Sentuh?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan