Menyebut Fungsi Tanpa Nama pada Baris yang Sama: Mengapa Ia Penting
Dalam konteks penutupan, fungsi tanpa nama sering digunakan pada baris yang sama sebagaimana yang ditakrifkan. Amalan ini menimbulkan persoalan tentang mekanisme asas dan sebab di sebaliknya.
Dalam Javascript, fungsi boleh ditakrifkan menggunakan tiga kaedah. Pertama, pembina Fungsi mencipta fungsi menggunakan kata kunci baharu. Kedua, pengisytiharan fungsi menggunakan kata kunci fungsi dan nama fungsi. Akhir sekali, ungkapan fungsi menetapkan fungsi kepada pembolehubah tanpa menyatakan nama.
Dalam kod yang disediakan, fungsi tanpa nama ditakrifkan menggunakan ungkapan fungsi:
(function(msg){alert(msg)})('SO');
Walau bagaimanapun, jika koma bertitik selepas definisi fungsi digugurkan, kod gagal:
(function (msg){alert(msg)}) ('SO');
Ini kerana tanpa koma bertitik, kod ditafsirkan sebagai dua pernyataan berasingan:
Ini tidak betul dari segi semantik, kerana fungsi itu bukan ditakrifkan sebelum ia dipanggil. Untuk mengelakkan ralat ini, koma bertitik mesti ada.
Sebagai alternatif, ungkapan fungsi boleh ditakrifkan dan digunakan seperti berikut:
var myFunc = function(msg){alert(msg);} myFunc('SO');
Dalam kes ini, fungsi ditetapkan kepada pembolehubah sebelum ia dipanggil. Walau bagaimanapun, pendekatan ini memerlukan fungsi bernama, yang mungkin tidak selalu diingini.
Amalan menggunakan fungsi tanpa nama pada baris yang sama membolehkan pelaksanaan fungsi segera tanpa memerlukan pembolehubah bernama. Ini amat berguna apabila merangkumkan kod yang perlu dilaksanakan sekali sahaja. Selain itu, ia membantu mengelakkan konflik penamaan dan mengurangkan bilangan pembolehubah global dalam pangkalan kod.
Untuk pemahaman lanjut tentang fungsi dan ungkapan fungsi tanpa nama, rujuk spesifikasi skrip ECMA (Seksyen 13 Definisi Fungsi) atau sumber tambahan seperti "jQuery dan $ questions" atau contoh yang disediakan dalam coretan kod di atas.
Atas ialah kandungan terperinci Mengapa Kami Mendapat Fungsi JavaScript Tanpa Nama pada Baris Sama yang Ditakrifkan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!