Rumah >hujung hadapan web >tutorial js >Penyelesaian untuk mencetuskan klik peristiwa dua kali dalam kemahiran iScroll_javascript
Saya telah membaca banyak artikel rakan membincangkan isu ini sebelum ini. Sebagai contoh, gunakan pembolehubah untuk merekodkan selang pelaksanaan atau sesuatu. Rasa macam kena melancap setiap kali memang agak memenatkan. Saya suka memilih alatan sebelum mengalihkan batu bata. Malah, penyelesaian kepada masalah ini sangat mudah. iScroll sebenarnya memintas peristiwa mula sentuh dan akhir sentuh apabila penyemak imbas diklik. Gunakan js untuk mencetuskan acara onclick elemen (fungsi _end) apabila menyentuh hujung. Dalam operasi sebenar, touchend dilaksanakan dahulu, dan kemudian fungsi berkaitan onclick dilaksanakan. Ini menimbulkan sakit kepala satu klik dan dua pencetus. Ini bukan masalah pada mulanya. Sebab mengapa ini menjadi masalah ialah kita perlu melihat kod sumber iScroll. Cara untuk menyelesaikan masalah ini adalah dengan menolak untuk melaksanakan fungsi untuk kali kedua. Dan logik saya betul-betul sama. Kita boleh mengalih keluar fungsi yang terikat pada acara onclick selepas melaksanakan kod yang mencetuskan acara klik dalam fungsi _end. Kemudian tambahkan acara itu semula selepas beberapa ratus milisaat masa. Contohnya:
Selepas mengalih keluar fungsi berkaitan onclick, fungsi ujian secara semula jadi tidak akan dicetuskan untuk kali kedua. Untuk terus menggunakannya pada masa akan datang, kami boleh menggunakan setTimeout untuk memulihkan kandungan onclick.
Kod sumber iskrol yang diubah suai (kira-kira 550 hingga 570 baris, dalam fungsi _end):
Fungsi _clickBack dan coretan kod hashBox (ditambah sebelum fungsi _end)
Sudah tentu, ia juga boleh dilaksanakan melalui fungsi awam tanpa mengubah suai kod sumber iscroll.
Di atas adalah semua kandungan artikel ini saya harap ia akan membantu semua orang untuk belajar menggunakan kawalan gelongsor iscroll