Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk Menghentikan Borang daripada Dihantar pada Tekan Kekunci ENTER?

Bagaimana untuk Menghentikan Borang daripada Dihantar pada Tekan Kekunci ENTER?

DDD
DDDasal
2024-11-09 04:17:02573semak imbas

How to Stop a Form from Submitting on ENTER Keypress?

Menghalang Penyerahan Borang pada ENTER Keypress

Dalam aplikasi web, kekunci ENTER sering digunakan untuk menghantar borang. Walau bagaimanapun, kadangkala adalah wajar untuk menghalang borang daripada diserahkan pada kekunci ENTER. Di bawah ialah dua kaedah untuk mencapai ini:

Kaedah 1: Pengendali Onkeypress

Kaedah ini menggunakan pengendali acara onkeypress pada borang. Dengan mencipta fungsi yang menyemak sama ada kekunci yang ditekan ialah ENTER (kod kekunci 13) dan membenarkan penyerahan borang hanya jika ia bukan ENTER, kita boleh menghalang penyerahan borang serta-merta. Kod untuk pendekatan ini ialah:

function checkEnter(e) {
  e = e || event;
  var txtArea = /textarea/i.test((e.target || e.srcElement).tagName);
  return txtArea || (e.keyCode || e.which || e.charCode || 0) !== 13;
}
document.querySelector('form').onkeypress = checkEnter;

Kaedah 2: Delegasi Acara dengan JavaScript Moden

Pendekatan yang lebih moden menggunakan ES20xx dan delegasi acara melibatkan penetapan pendengar penekan kekunci pada keseluruhan dokumen. Kaedah ini menyemak sama ada borang yang mengandungi input sasaran mempunyai atribut khas yang menunjukkan bahawa tekan kekunci ENTER harus menyerahkan borang tersebut. Kod JavaScript dan HTML yang berkaitan:

document.addEventListener(`keypress`, handle);

function handle(evt) {
  const form = evt.target.closest(`#testForm`);
  if (form) {
    if (evt.target.dataset.enterForSubmit) {
      if (evt.key === `Enter`) {
        evt.preventDefault();
        return logClear(`won't submit "${evt.target.value}"`);
      }
      return true;
    }
  }
}
<form>

Kedua-dua kaedah ini berkesan menghalang borang daripada diserahkan pada tekan kekunci ENTER sambil membenarkan input textarea, yang secara semula jadi menggunakan ENTER untuk pemisah baris, berfungsi secara normal.

Atas ialah kandungan terperinci Bagaimana untuk Menghentikan Borang daripada Dihantar pada Tekan Kekunci ENTER?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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