Rumah > hujung hadapan web > uni-app > Bagaimana untuk mengelakkan papan kekunci daripada hilang apabila mengklik butang dalam uniapp

Bagaimana untuk mengelakkan papan kekunci daripada hilang apabila mengklik butang dalam uniapp

PHPz
Lepaskan: 2023-04-23 10:31:41
asal
1228 orang telah melayarinya

Dengan perkembangan pesat Internet mudah alih, semakin banyak syarikat dan pembangun mula menumpukan pada pembangunan aplikasi berasaskan mudah alih. Sebagai rangka kerja pembangunan berbilang terminal baharu, UniApp telah menjadi pilihan semakin ramai pembangun. Semasa proses pembangunan UniApp, kami sering menghadapi keperluan untuk mengklik butang untuk membuat papan kekunci hilang. Artikel ini akan memperkenalkan cara untuk menghalang papan kekunci daripada hilang apabila mengklik butang dalam UniApp untuk membantu pembangun membangunkan aplikasi mudah alih dengan lebih baik.

1. Analisis Keperluan

Semasa penggunaan aplikasi mudah alih, pengguna selalunya perlu mengklik pada bahagian lain halaman untuk membuat papan kekunci hilang apabila papan kekunci muncul untuk memudahkan operasi lain. Tetapi dalam beberapa kes, seperti carian atau input borang, mengklik butang tidak seharusnya membuat papan kekunci hilang untuk memudahkan pengguna meneruskan operasi input. Oleh itu, keperluan kami adalah untuk mencapai kesan tidak membiarkan papan kekunci hilang apabila tetikus mengklik butang melalui kawalan pengaturcaraan berdasarkan situasi sebenar.

2. Idea pelaksanaan

Dalam pembangunan UniApp, kami boleh mengawal interaksi antara halaman dan papan kekunci dengan mengikat peristiwa klik butang dan melaksanakan kod JavaScript. Idea pelaksanaan khusus adalah seperti berikut:

1. Ikat peristiwa klik butang supaya kita boleh menangkap isyarat klik butang.

2 Dalam kod JavaScript yang mengendalikan acara klik, dapatkan status halaman semasa dan tentukan sama ada papan kekunci perlu hilang.

3 Jika halaman semasa perlu membuat papan kekunci hilang, cetuskan acara untuk membuat papan kekunci hilang.

4 Jika halaman semasa tidak memerlukan papan kekunci hilang, jangan lakukan apa-apa dan benarkan pengguna meneruskan operasi input.

3. Pelaksanaan Kod

Sebelum pelaksanaan, adalah perlu untuk menentukan sama ada papan kekunci telah muncul pada halaman. Jika papan kekunci tidak muncul, mengklik butang tidak mempunyai kesan. Jika papan kekunci telah muncul, tentukan sama ada butang semasa perlu membuat papan kekunci hilang. Jika perlu, panggil uni.hideKeyboard() untuk membuat papan kekunci hilang. Jika tidak diperlukan, jangan lakukan apa-apa.

Berikut ialah contoh pelaksanaan kod:

<template>
  <view>
    <input type="text" @focus="focusInput" placeholder="请输入内容"/>
    <button @tap="buttonTap">点击我</button>
  </view>
</template>

<script>
  export default {
    methods: {
      buttonTap() {
        // 判断键盘是否已弹出
        uni.getSystemInfo({
          success: res => {
            const { platform } = res
            if (platform === 'ios') {
              const query = uni.createSelectorQuery()
              query.select('#input').boundingClientRect()
              query.selectViewport().scrollOffset()
              query.exec(function (res) {
                const height = window.innerHeight - res[0].bottom
                if (height > 0) {
                  // 键盘未弹出
                  return
                } else {
                  // 键盘已弹出
                  uni.hideKeyboard()
                }
              })
            } else {
              const query = uni.createSelectorQuery()
              query.select('#input').boundingClientRect()
              query.selectViewport().scrollOffset()
              query.exec(function (res) {
                const height = res[0].height - (window.innerHeight - res[0].bottom)
                if (height > 0) {
                  // 键盘未弹出
                  return
                } else {
                  // 键盘已弹出
                  uni.hideKeyboard()
                }
              })
            }
          }
        })
      }
    }
  }
</script>
Salin selepas log masuk

Dalam kod di atas, kami mula-mula menentukan sama ada papan kekunci telah muncul dan mendapatkan ketinggian halaman semasa. Kemudian tentukan sama ada halaman semasa perlu membuat papan kekunci hilang berdasarkan ketinggian. Akhir sekali, hilangkan papan kekunci dengan memanggil uni.hideKeyboard(). Dengan cara ini, anda sentiasa boleh memastikan bahawa papan kekunci tidak akan hilang apabila anda mengklik butang.

4. Ringkasan

Artikel ini memperkenalkan cara untuk menghalang papan kekunci daripada hilang apabila mengklik butang dalam UniApp. Idea khusus adalah untuk mengikat acara klik butang dan melaksanakannya melalui kawalan pengaturcaraan mengikut situasi sebenar Pelaksanaan kod adalah mudah dan jelas. Jika anda ingin membangunkan aplikasi mudah alih dalam UniApp dan perlu melaksanakan ciri ini, anda boleh menggunakan kaedah ini sebagai rujukan.

Atas ialah kandungan terperinci Bagaimana untuk mengelakkan papan kekunci daripada hilang apabila mengklik butang 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