<input type="checkbox" onclick="onClickHandler()" onchange="onChangeHandler()" />
Dari dalam onClickHandler
dan / atau onChangeHandler
, bagaimana saya bisa menentukan keadaan baru kotak centang itu?
Jawaban singkatnya:
Gunakan click
acara, yang tidak akan menyala sampai setelah nilai diperbarui, dan diaktifkan saat Anda menginginkannya:
<label><input type='checkbox' onclick='handleClick(this);'>Checkbox</label>
function handleClick(cb) {
display("Clicked, new value = " + cb.checked);
}
Jawaban yang lebih panjang:
Pengatur change
kejadian tidak dipanggil sampai checked
keadaan telah diperbarui ( contoh langsung | sumber ), tetapi karena (seperti yang ditunjukkan Tim Büthe di komentar) IE tidak memecat change
acara sampai kotak centang kehilangan fokus, Anda tidak mendapatkan pemberitahuan secara proaktif. Lebih buruk lagi, dengan IE jika Anda mengklik label untuk kotak centang (bukan kotak centang itu sendiri) untuk memperbaruinya, Anda bisa mendapatkan kesan bahwa Anda mendapatkan nilai lama (coba dengan IE di sini dengan mengklik label: live example | sumber ). Ini karena jika kotak centang memiliki fokus, mengklik label menjauhkan fokus darinya, menembakkan change
acara dengan nilai lama, dan kemudianclick
terjadi pengaturan nilai baru dan pengaturan fokus kembali pada kotak centang. Sangat membingungkan.
Tapi Anda bisa menghindari semua ketidaknyamanan itu jika Anda menggunakannya click
.
Saya telah menggunakan penangan DOM0 ( onxyz
atribut) karena itulah yang Anda tanyakan, tetapi sebagai catatan, saya biasanya akan merekomendasikan mengaitkan penangan dalam kode (DOM2 addEventListener
, atau attachEvent
dalam versi IE yang lebih lama) daripada menggunakan onxyz
atribut. Itu memungkinkan Anda melampirkan banyak penangan ke elemen yang sama dan memungkinkan Anda menghindari membuat semua fungsi penangan Anda menjadi global.
Versi sebelumnya dari jawaban ini menggunakan kode ini untuk handleClick
:
function handleClick(cb) {
setTimeout(function() {
display("Clicked, new value = " + cb.checked);
}, 0);
}
Tujuannya adalah untuk memungkinkan klik untuk menyelesaikan sebelum melihat nilainya. Sejauh yang saya ketahui, tidak ada alasan untuk melakukan itu, dan saya tidak tahu mengapa saya melakukannya. Nilai diubah sebelum click
pawang dipanggil. Bahkan, speknya cukup jelas tentang itu . Versi tanpa setTimeout
berfungsi dengan baik di setiap browser yang saya coba (bahkan IE6). Saya hanya bisa berasumsi saya sedang memikirkan platform lain di mana perubahan tidak dilakukan sampai setelah acara. Bagaimanapun, tidak ada alasan untuk melakukan itu dengan kotak centang HTML.
onchange
berfungsi dengan benar di+IE9
. Sumbertab
+space
) juga akan memicuonclick
penangan (setidaknya diverifikasi di Chrome 51).Untuk React.js, Anda dapat melakukan ini dengan kode yang lebih mudah dibaca. Semoga ini bisa membantu.
sumber
Gunakan ini
sumber