Rumah > hujung hadapan web > Soal Jawab bahagian hadapan > JavaScript mempunyai beberapa acara papan kekunci

JavaScript mempunyai beberapa acara papan kekunci

青灯夜游
Lepaskan: 2022-02-17 18:15:04
asal
3647 orang telah melayarinya

Javascript mempunyai tiga jenis acara papan kekunci: 1. acara kekunci kekunci, yang dicetuskan apabila kekunci tertentu ditekan pada papan kekunci; 3. acara keyup, Menyala apabila kekunci papan kekunci dilepaskan.

JavaScript mempunyai beberapa acara papan kekunci

Persekitaran pengendalian tutorial ini: sistem Windows 7, versi JavaScript 1.8.5, komputer Dell G3.

Dalam JavaScript, peristiwa papan kekunci dicetuskan apabila pengguna mengendalikan papan kekunci.

Acara papan kekunci terutamanya termasuk 3 jenis berikut:

  • keydown: dicetuskan apabila kekunci ditekan pada papan kekunci. Jika anda menahan kekunci, peristiwa ini akan dicetuskan secara berterusan, tetapi penyemak imbas Opera tidak menyokong operasi berterusan ini. Apabila pengendali acara mengembalikan palsu, tindakan lalai (seperti memasukkan aksara papan kekunci dan tindak balas acara penekanan kekunci dalam pelayar IE dan Safari) akan dibatalkan.

  • keypress: Dicetuskan apabila kekunci papan kekunci ditekan dan dilepaskan. Jika kekunci ditekan, acara ini akan dicetuskan secara berterusan. Apabila pengendali acara mengembalikan palsu, tindakan lalai (seperti aksara papan kekunci yang dimasukkan) akan dibatalkan.

  • keyup: Dicetuskan apabila kekunci papan kekunci dilepaskan. Peristiwa ini hanya dicetuskan sekali apabila papan kekunci dilepaskan dan bukan keadaan tindak balas berterusan.

Apabila mendapat kod kunci yang ditekan pengguna, anda boleh menggunakan acara keydown, penekanan kekunci dan keyup untuk mendapatkan maklumat ini. Acara tekan kekunci dan kekunci pada asasnya adalah acara yang sinonim, dan persembahannya adalah sama, bagaimanapun, sesetengah penyemak imbas tidak membenarkan peristiwa tekan kekunci digunakan untuk mendapatkan maklumat utama. Semua elemen menyokong acara papan kekunci, tetapi acara papan kekunci kebanyakannya digunakan dalam input bentuk.

Contoh

Contoh berikut menangkap pelbagai butiran operasi papan kekunci dalam masa nyata, iaitu jenis acara tindak balas papan kekunci dan nilai kunci yang sepadan.

<textarea id="key"></textarea>
<script>
    var key = document.getElementById("key");
    key.onkeydown =f;  //注册keydown事件处理函数
    key.onkeyup = f;  //注册keyup事件处理函数
    key.onkeypress = f;  //注册keypress事件处理函数
    function f (e) {
        var e = e || window.event;  //标准化事件处理
        var s = e.type + " " + e.keyCode;  //获取键盘事件类型和按下的值
        key.value = s;
    }
</script>
Salin selepas log masuk

Sifat acara papan kekunci

Papan kekunci mentakrifkan banyak sifat, seperti yang ditunjukkan dalam jadual di bawah. Gunakan sifat ini untuk mengawal operasi papan kekunci dengan tepat. Sifat acara papan kekunci biasanya hanya wujud dalam objek acara apabila peristiwa berkaitan papan kekunci berlaku, kecuali sifat ctrlKey dan shiftKey, kerana ia boleh wujud dalam peristiwa pengekalan air. Sebagai contoh, klik tetikus berlaku apabila kekunci Ctrl atau Shift ditekan.

键盘事件定义的属性
属性 说明
keyCode 该属性包含键盘中对应键位的键值
charCode 该属性包含键盘中对应键位的 Unicode 编码,仅 DOM 支持
target 发生事件的节点(包含元素),仅 DOM 支持
srcElement 发生事件的元素,仅 IE 支持
shiftKey 是否按下 Shift 键,如果按下返回 true,否则为false
ctrlKey 是否按下 Ctrl 键,如果按下返回 true,否则为false
altKey 是否按下 Alt 键,如果按下返回 true,否则为false
metaKey 是否按下 Mtea 键,如果按下返回 true,否则为false,仅 DOM 支持

[Cadangan berkaitan: Tutorial pembelajaran javascript]

Atas ialah kandungan terperinci JavaScript mempunyai beberapa acara papan kekunci. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
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