Contoh dalam artikel ini menerangkan cara melaksanakan acara ketik untuk mengelakkan menggelegak dalam zepto.js. Kongsikan dengan semua orang untuk rujukan anda. Butirannya adalah seperti berikut:
Saya sedang mengusahakan versi mudah alih tapak web saya pada asalnya saya mahu menggunakan jQuery Mobile, tetapi fail itu terlalu besar, jadi saya menggunakan zepto.js
.Memandangkan terdapat kelewatan apabila menggunakan acara klik pada halaman web mudah alih, acara ketik dalam zepto.js digunakan.
Menggunakan acara klik, anda boleh menggunakan stopPropagation untuk mengelakkan menggelegak, tetapi kaedah ini tidak sah untuk ketik
Sekarang saya perlu mencapai kesan sedemikian: klik butang a.btn, kemudian paparkan div.panel dan sembunyikan div.panel apabila saya mengklik pada non-div.panel
$("a.btn").on("tap",function(e){ e.stopPropagation();//该方法不起作用 $("div.panel").show(); }); $(document).on("tap",function(e){ $("div.panel").hide(); });
Melalui alat penyahpepijatan, kita boleh mendapatkan bahawa terdapat atribut sasaran dalam objek e, jadi kita boleh menggunakan atribut ini untuk mencapai kesan yang diingini:
$("a.btn").on("tap",function(){ $("div.panel").show(); }); $(document).on("tap",function(e){ if(!$(e.target).hasClass("btn")){ $("div.panel").hide(); } });
Inilah penyelesaiannya
Saya harap artikel ini akan membantu reka bentuk pengaturcaraan JavaScript semua orang.