Rumah >hujung hadapan web >tutorial js >Pengenalan kepada beberapa cara untuk memanggil kaedah fungsi dalam kemahiran Javascript_javascript
Sintaks JavaScript adalah fleksibel, dan tidak jarang terdapat lima atau enam cara untuk melaksanakan fungsi yang sama Ditambah dengan beberapa warisan prototaip anti-manusia dan ciri tak segerak, ia menjadi lebih mengelirukan. Saya sering tidak faham perbezaan antara panggilan dan memohon saya akan merakamnya hari ini supaya tidak melupakannya lagi.
Dalam JavaScript, kaedah boleh dilaksanakan dengan cara berikut:
1.func(), ini adalah kaedah panggilan yang paling langsung dan biasa, dan ia juga selaras dengan logik pemikiran orang biasa Walau bagaimanapun, ia mempunyai beberapa kelemahan dalam beberapa kes, yang akan diterangkan di bawah.
2. (function(arg){})(window), panggilan kaedah tanpa nama, adalah lebih berguna apabila membina ruang nama Parameter dalam kurungan berikut sepadan dengan parameter input dalam kaedah tanpa nama.
3.func.bind(sth)(), manual mozilla menyebut bahawa bind ialah ciri baharu yang ditambah dalam ECMA-262 Edisi Ke-5, yang disenaraikan secara berasingan di sini Sebagai kaedah panggilan, ia menebus kecacatan tidak dapat mengikat skop dalam panggilan langsung.
4.func.call(), ini ialah kaedah panggilan kedua Kaedah panggilan ditakrifkan dalam prototaip setiap kaedah untuk melaksanakan kaedah semasa.
5.func.apply(), abang kembar call.
func()
Ini ialah kaedah panggilan yang paling biasa dan boleh didapati di mana-mana dalam mana-mana bahasa. func(x, y) boleh lulus dalam parameter yang berbeza. Dalam sesetengah bahasa, seperti php dan java, panggilan ini cukup untuk menyelesaikan semua masalah. Tetapi JavaScript ialah bahasa yang berfungsi, dan konsep penutupan serta kata kunci pelik ini menentukan kelemahan kaedah panggilan ini. Ini harus ditafsirkan sebagai skop segmen kod semasa, yang akan berubah apabila kod dilaksanakan kepada segmen yang berbeza Walau bagaimanapun, dalam beberapa kes kami tidak mahu ini diubah, seperti peristiwa yang terikat pada beberapa DOM, kami pasti Kami tidak mahu ini dipindahkan ke objek tetingkap apabila ia dipanggil, tetapi kadangkala ia adalah, seperti kod berikut.
Anda boleh menganggap a sebagai pautan pada halaman Memandangkan kami hanya mahu mengikat kaedah yang ditentukan kepada acara onclick dan bukannya memanggilnya dengan segera, dan kaedah ini mempunyai parameter, kami perlu menggunakan kaedah tanpa nama ia dan hantar ke acara onclick a. Terdapat masalah ini dalam func menjadi tetingkap objek global Jelas sekali kita tidak mahu ini. Pada masa ini, panggilan terus menggunakan func() tidak akan berfungsi, jadi kita perlu mengikat fungsi luar ini kepada kaedah func. Jadi terdapat kaedah bind, call, dan apply.
ikat
Tujuan bind sangat mudah, kembalikan kaedah yang sama terikat pada objek ini. Mengubah suai satu baris kod di atas boleh mencapai tujuan mengikat ini pada objek.
Dengan cara ini, acara onclick ini tidak akan berjalan seperti lalat tanpa kepala.
hubungi & mohon
Panggilan dan mohon hendaklah disebut bersama kerana ia sangat serupa. Kedua-duanya menyokong berbilang parameter, dan parameter pertama ialah objek ini yang akan diikat. Parameter kedua ialah perbezaan antara mereka menggunakan parameter bebas sebagai parameter input kaedah panggilan, dan memohon menggunakan tatasusunan sebagai parameter input . Kadang-kadang kita tidak mahu menukar objek ini, tetapi kita mahu mengikatnya pada objek lain secara buatan Pada masa ini, panggil dan gunakan adalah sangat berguna. (Ini tidak bermakna anda tidak boleh menggunakan bind, tetapi nampaknya bind muncul agak lewat, dan mungkin keserasian penyemak imbas tidak baik). Beri saya contoh:
Objek a dan b di atas kedua-duanya mempunyai x. Kami berharap func boleh mengubah suai x yang sepadan dengan cara yang disasarkan, tetapi panggilan langsung hanya boleh mengubah suai x dalam skop func, iaitu a.x. Dengan mengubah suai kod, anda boleh mencapai tujuan mengubah suai b.x
Berangan ini tidak dipersembahkan dengan baik, ia adalah gaya pengekodan yang mudah mengelirukan, tetapi ia tidak boleh digunakan di semua tempat.