Rumah > hujung hadapan web > tutorial js > `.keyCode` vs. `.which`: Manakah Pengecam Kekunci Peristiwa Penekanan Kekunci Terbaik?

`.keyCode` vs. `.which`: Manakah Pengecam Kekunci Peristiwa Penekanan Kekunci Terbaik?

DDD
Lepaskan: 2024-10-30 06:49:28
asal
751 orang telah melayarinya

  `.keyCode` vs. `.which`: Which is the Best Keypress Event Key Identifier?

Pengenalpastian Kunci Acara Tekan Kekunci: .keyCode vs. .which

Dalam mengendalikan acara penekanan kekunci, pembangun sering menghadapi pilihan antara menggunakan .keyCode dan .yang menentukan ketukan kekunci. Walaupun kedua-duanya berfungsi untuk mengenal pasti kekunci yang ditekan, terdapat perbezaan yang ketara dan pertimbangan keserasian merentas penyemak imbas.

Secara sejarah, .keyCode digunakan secara meluas untuk mengesan penekanan kekunci, tetapi sokongannya tidak konsisten merentas penyemak imbas. Sesetengah menggunakan kod Unicode watak, manakala yang lain menggunakan nilai khusus platform. Ketidakkonsistenan ini boleh membawa kepada tingkah laku yang tidak dijangka dalam aplikasi merentas pelayar.

Sebaliknya, .yang merupakan pendekatan yang lebih normal. Ia mengembalikan nilai piawai yang mewakili pengecam logik kunci, tanpa mengira pelayar atau platform. Walau bagaimanapun, ia mungkin tidak disokong dalam penyemak imbas lama.

Untuk menangani isu merentas penyemak imbas yang berpotensi, jQuery menyeragamkan gelagat menekan kekunci dengan sentiasa menggunakan .which. Ia menukar nilai tidak standard daripada penyemak imbas yang berbeza kepada format yang konsisten, menjadikannya pilihan yang boleh dipercayai untuk keserasian merentas penyemak imbas.

Jika menggunakan JavaScript vanila, pembangun boleh memastikan keserasian penyemak imbas dengan menggunakan gabungan kedua-dua sifat, sebagai berikut:

<code class="js">var key = 'which' in e ? e.which : e.keyCode;</code>
Salin selepas log masuk

Kod ini menyemak sama ada .yang ditakrifkan dalam objek acara; jika ya, ia menggunakan nilainya. Jika tidak, ia akan kembali menggunakan .keyCode.

Sebagai alternatif, pendekatan yang lebih ringkas boleh digunakan:

<code class="js">var key = e.which || e.keyCode || 0;</code>
Salin selepas log masuk

Ungkapan ini mengendalikan kemungkinan .which menjadi 0 dengan memulihkannya kepada itu nilai pada penghujungnya, menggunakan operator OR logik JavaScript yang berkuasa (||).

Atas ialah kandungan terperinci `.keyCode` vs. `.which`: Manakah Pengecam Kekunci Peristiwa Penekanan Kekunci Terbaik?. 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