Rumah > hujung hadapan web > Soal Jawab bahagian hadapan > Bagaimana untuk menyesuaikan vue ke kotak hitam kecil di bawah telefon bimbit ios

Bagaimana untuk menyesuaikan vue ke kotak hitam kecil di bawah telefon bimbit ios

PHPz
Lepaskan: 2023-05-25 15:10:38
asal
747 orang telah melayarinya

Dalam projek Vue, jika kotak hitam kecil muncul pada telefon iOS, ia mungkin disebabkan oleh gelongsor halaman. Kotak hitam kecil ini biasanya muncul dalam penyemak imbas Safari pada iOS 12 dan ke atas. Berikut adalah beberapa penyelesaian.

Penyelesaian

Pilihan 1: Lumpuhkan gelongsor halaman iOS

Idea kaedah ini adalah untuk melarang halaman gelongsor untuk mengelakkan kemunculan kotak hitam kecil. Ini boleh dicapai dengan cara berikut:

Tambahkan kod berikut pada fungsi mounted dalam halaman yang masalahnya perlu diselesaikan:

document.body.addEventListener('touchmove', (e) => {
      e.preventDefault();
}, { passive: false });
Salin selepas log masuk

atau tambah kod berikut pada Komponen App.vue:

<script>
    export default {
        mounted() {
            document.body.addEventListener('touchmove', (e) => {
              e.preventDefault();
            }, { passive: false });
        }
    }
</script>
Salin selepas log masuk

Kesannya ialah untuk melumpuhkan acara gelongsor halaman dan menyelesaikan masalah kotak hitam kecil. Walau bagaimanapun, kaedah ini akan menjejaskan keadaan keseluruhan Jika beberapa halaman perlu diluncurkan, pemprosesan khas akan diperlukan untuk halaman ini.

Pilihan 2: Selesaikan melalui CSS

Menggunakan CSS untuk menyelesaikan juga merupakan kaedah yang agak mudah. Tambahkan kod berikut pada bekas induk:

-webkit-overflow-scrolling: touch;
overflow-y: scroll;
Salin selepas log masuk

Contohnya:

<div class="wrapper">
  <div class="content">
    <!-- 内容 -->
  </div>
</div>

<style>
.wrapper {
  -webkit-overflow-scrolling: touch;
  overflow-y: scroll;
}
</style>
Salin selepas log masuk

-webkit-overflow-scrolling di sini ialah sifat dalam CSS yang digunakan untuk mengawal mod tatal bekas. Selepas menambahkannya, kesan tatal elastik iOS akan didayakan untuk menyelesaikan masalah kotak hitam kecil, tetapi ia akan menyebabkan kesan tatal keseluruhan halaman berubah.

Pilihan 3: Gunakan tatal yang lebih baik

tatal yang lebih baik ialah perpustakaan yang menyelesaikan masalah tatal pada bahagian mudah alih Anda boleh menggunakan pustaka ini untuk menyelesaikan masalah kotak hitam kecil pada iOS.

Mula-mula, pasang better-scroll:

npm install better-scroll --save
Salin selepas log masuk

Kemudian perkenalkan dan mulakan lebih baik-scroll dalam halaman yang anda perlu gunakan:

<template>
  <div>
      <div ref="wrapper">
          <!--内容-->
      </div>
  </div>
</template>

<script>
import BScroll from 'better-scroll'

export default {
  mounted() {
    this.scroll = new BScroll(this.$refs.wrapper, {
      probeType: 3,
      click: true
    })
  }
}
</script>
Salin selepas log masuk

Apa yang perlu diperhatikan di sini ialah lebih baik -Pengamatan tatal perlu dilengkapkan dalam fungsi mounted komponen, jika tidak masalah mungkin berlaku.

Ringkasan

Di atas ialah tiga kaedah biasa untuk menyelesaikan masalah kotak hitam kecil dalam iOS. Melumpuhkan gelongsor halaman iOS ialah kaedah paling mudah, tetapi ia akan menjejaskan keadaan keseluruhan. Menggunakan CSS untuk menyelesaikan masalah boleh mengelakkan masalah global. Akhir sekali, jika anda perlu menggunakan tatal yang lebih baik dalam projek anda, anda perlu memberi perhatian kepada masa permulaan.

Atas ialah kandungan terperinci Bagaimana untuk menyesuaikan vue ke kotak hitam kecil di bawah telefon bimbit ios. 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