Rumah > hujung hadapan web > uni-app > Bagaimana untuk melumpuhkan tatal lalai dalam uniapp

Bagaimana untuk melumpuhkan tatal lalai dalam uniapp

PHPz
Lepaskan: 2023-04-20 09:14:10
asal
2510 orang telah melayarinya

Dalam pembangunan mudah alih, kami sering menghadapi keperluan untuk melumpuhkan tatal lalai. Sebagai contoh, apabila menggunakan uniapp untuk membangunkan program kecil, anda mungkin perlu melarang penatalan lalai halaman dalam beberapa senario Dalam kes ini, kami perlu menggunakan beberapa kaedah yang disediakan oleh uniapp untuk mencapai ini.

Pertama sekali, kita perlu memahami bahawa dalam uniapp, halaman menyokong penatalan secara lalai. Oleh itu, jika kita ingin melumpuhkan tatal lalai, kita perlu menggunakan beberapa helah.

Kaedah 1: Dengan menetapkan gaya bekas luar

Kami boleh melumpuhkan tatal lalai halaman dengan menetapkan gaya bekas luar. Langkah khusus adalah seperti berikut:

  1. Tetapkan bekas luar pada halaman, seperti teg div.
  2. Tetapkan gaya untuk bekas luar, termasuk limpahan:tersembunyi.
  3. Dalam kawasan halaman yang menatal perlu dilumpuhkan, seperti teg div, tetapkan gaya, limpahan-y: tatal;.

Contoh kod:

<template>
  <div class="wrapper">
    <div class="content" style="overflow-y: scroll;">
      <!--此处为需要设置滚动的内容区域-->
    </div>
  </div>
</template>

<style>
  .wrapper {
    overflow: hidden;
  }
</style>
Salin selepas log masuk

Melalui kaedah di atas, kita boleh mencapai kesan melumpuhkan tatal lalai halaman.

Kaedah 2: Pelaksanaan melalui kod JS

Jika struktur halaman rumit, atau penatalan perlu dikawal dalam senario tertentu tertentu, kami boleh menggunakan kod JS untuk mencapai kesan melumpuhkan penatalan.

Langkah khusus adalah seperti berikut:

  1. Dapatkan elemen halaman yang perlu dilumpuhkan, seperti bekas menatal.
  2. Ikat permulaan sentuh, gerakan sentuh, acara sentuh tamat dan cegah peristiwa lalai dalam fungsi pengendalian acara.

Contoh kod:

<script>
  export default {
    methods: {
      stopScroll() {
        let el = document.querySelector('.content');
        let startY;
        el.addEventListener('touchstart', (e) => {
          startY = e.touches[0].pageY;
        });
        el.addEventListener('touchmove', (e) => {
          let moveY = e.touches[0].pageY - startY;
          if (el.scrollTop === 0 && moveY > 0) {
            e.preventDefault();
          }
          if (el.scrollTop >= el.scrollHeight - el.offsetHeight && moveY < 0) {
            e.preventDefault();
          }
        });
        el.addEventListener(&#39;touchend&#39;, () => {
          startY = 0;
        });
      },
    },
    mounted() {
      this.stopScroll();
    },
  };
</script>
Salin selepas log masuk

Kod di atas dipanggil dalam kitaran hayat yang dipasang Kami memperoleh elemen bekas yang perlu dilumpuhkan dan mengikat touchStart dan touchmove acara, dan kendalikan gelongsor bar skrol dalam fungsi pengendalian acara untuk mencapai kesan melarang penatalan.

Ringkasan

Melalui dua kaedah di atas, kita boleh mencapai kesan melumpuhkan tatal lalai halaman. Kaedah pelaksanaan khusus boleh dipilih mengikut keperluan projek sebenar.

Sudah tentu, jika anda menggunakan kaedah kedua, anda juga perlu memberi perhatian kepada isu prestasi, kerana peristiwa touchmove akan dicetuskan setiap kali anda menatal, dan scrollTop dan scrollHeight elemen perlu dikira semula . Oleh itu, semasa penggunaan, adalah perlu untuk mengoptimumkan kod sebanyak mungkin untuk meningkatkan prestasi.

Atas ialah kandungan terperinci Bagaimana untuk melumpuhkan tatal lalai dalam uniapp. 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