Rumah hujung hadapan web tutorial js Perbincangan terperinci tentang fungsi tanpa nama JavaScript dan kemahiran closures_javascript

Perbincangan terperinci tentang fungsi tanpa nama JavaScript dan kemahiran closures_javascript

May 16, 2016 pm 04:31 PM
javascript fungsi tanpa nama penutupan

1. Fungsi tanpa nama
Fungsi ialah objek yang paling fleksibel dalam JavaScript Di sini kami hanya menerangkan penggunaan fungsi tanpa nama. Fungsi tanpa nama: Ia adalah fungsi tanpa nama fungsi.

1.1 Definisi fungsi, mula-mula memperkenalkan secara ringkas definisi fungsi, yang boleh dibahagikan secara kasar kepada tiga cara

Jenis pertama: Ini juga merupakan jenis yang paling biasa

Salin kod Kod adalah seperti berikut:

fungsi ganda(x){
Kembalikan 2 * x; }

Kaedah kedua: Kaedah ini menggunakan pembina Fungsi dan menganggap kedua-dua senarai parameter dan badan fungsi sebagai rentetan Ini sangat menyusahkan dan tidak disyorkan.

Salin kod Kod adalah seperti berikut:
var double = new Function('x', 'return 2 * x;');

Jenis ketiga:

var double = function(x) { return 2* x; Ambil perhatian bahawa fungsi di sebelah kanan "=" ialah fungsi tanpa nama Selepas mencipta fungsi, fungsi itu diberikan kepada petak pembolehubah.


1.2 Penciptaan fungsi tanpa nama

Kaedah pertama ialah mentakrifkan fungsi segi empat sama seperti yang dinyatakan di atas, yang juga merupakan salah satu kaedah yang paling biasa digunakan.

Cara kedua:

(fungsi(x, y){
makluman(x y); })(2, 3);



Fungsi tanpa nama dicipta di sini (di dalam kurungan pertama), dan kurungan kedua digunakan untuk memanggil fungsi tanpa nama dan menghantar parameter.
2. Penutup

Perkataan Inggeris untuk penutupan ialah penutupan, yang merupakan bahagian pengetahuan yang sangat penting dalam JavaScript, kerana menggunakan penutupan boleh mengurangkan jumlah kod kami, menjadikan kod kami kelihatan lebih jelas, dsb. Pendek kata, ia sangat berkuasa.

Maksud penutupan: Secara terang-terangan, penutupan ialah sarang fungsi Fungsi dalam boleh menggunakan semua pembolehubah fungsi luar, walaupun fungsi luar telah dilaksanakan (ini melibatkan rantaian skop JavaScript).

Contoh 1

Salin kod Kod adalah seperti berikut: fungsi checkClosure(){
var str = 'manusia hujan';
setTimeout(
           function(){ alert(str); } //Ini ialah fungsi tanpa nama
, 2000);
}
checkClosure();



Contoh ini kelihatan sangat mudah masih terdapat banyak mata pengetahuan selepas analisis teliti proses pelaksanaannya: pelaksanaan fungsi checkClosure adalah serta-merta (mungkin hanya mengambil masa 0.00001 milisaat), dan str pembolehubah dibuat dalam badan fungsi daripada checkClosure , str tidak dikeluarkan selepas checkClosure dilaksanakan, kerana fungsi tanpa nama dalam setTimeout mempunyai rujukan kepada str. Selepas 2 saat, fungsi tanpa nama dalam badan fungsi dilaksanakan dan str dikeluarkan.
Contoh 2, kod dioptimumkan

Salin kod Kod adalah seperti berikut: fungsi untukTimeout(x, y){
makluman(x y);
}
kelewatan fungsi(x, y, masa){
setTimeout('forTimeout(' x ',' y ')' , masa); }
/**
* Fungsi kelewatan di atas sangat sukar dibaca dan tidak mudah ditulis, tetapi jika anda menggunakan penutupan, kod boleh dibuat lebih jelas
* kelewatan fungsi(x, y, masa){
* setTimeout(
* fungsi(){
* forTimeout(x, y)
*                                                                                         * , masa);
* }
,*/



3. Contoh
Penggunaan terbesar fungsi tanpa nama adalah untuk membuat penutupan (yang merupakan salah satu ciri bahasa JavaScript), dan juga boleh membina ruang nama untuk mengurangkan penggunaan pembolehubah global.
Contoh 3:


Salin kod

Kod adalah seperti berikut:

var oEvent = {};
(fungsi(){
var addEvent = function(){ /*Pelaksanaan kod diabaikan*/ };
Function removeEvent(){}

oEvent.addEvent = addEvent;
oEvent.removeEvent = removeEvent;
})();

Dalam kod ini, fungsi addEvent dan removeEvent ialah pembolehubah tempatan, tetapi kita boleh menggunakannya melalui pembolehubah global oEvent, yang mengurangkan penggunaan pembolehubah global dan meningkatkan keselamatan halaman web. Kami mahu menggunakan kod ini: oEvent.addEvent(document.getElementById('box') , 'click' , function(){});

Contoh 4:

Salin kod Kod adalah seperti berikut:

var rainman = (fungsi(x , y){
Kembalikan x y;
})(2, 3);
/**
* boleh juga ditulis dalam bentuk berikut, kerana kurungan pertama hanya membantu kita membaca, tetapi format penulisan berikut tidak digalakkan.
* var rainman = fungsi(x, y){
* kembalikan x y;
* }(2, 3);
,*/

Di sini kami mencipta rainman berubah-ubah dan memulakannya kepada 5 dengan memanggil terus fungsi tanpa nama ini kadangkala sangat praktikal.

Contoh 5:

Salin kod Kod adalah seperti berikut:

var outer = null;
(fungsi(){
var satu = 1;
Berfungsi dalam (){
         satu = 1;
makluman(satu);
}
luar = dalam;
})();
luar(); //2
luar(); //3
luar(); //4

Pembolehubah dalam kod ini ialah pembolehubah tempatan (kerana ia ditakrifkan dalam fungsi), jadi ia tidak boleh diakses dari luar. Tetapi di sini kami mencipta fungsi dalam, yang boleh mengakses pembolehubah satu; dan pembolehubah global luar merujuk kepada dalam, jadi memanggil luar tiga kali akan muncul hasil tambahan.

4 4.1 Penutupan membenarkan fungsi dalaman merujuk kepada pembolehubah dalam fungsi induk, tetapi pembolehubah ialah nilai akhir

Contoh 6:

Salin kod Kod adalah seperti berikut:
/**
 *
 *

     *    
  • one

  •  *    
  • dua

  •  *    
  • tiga

  •  *    
  • one

  •  *

 */
var lists = document.getElementsByTagName('li');

for(var i = 0 , len = lists.length ; i < len ; i ){
Senaraikan[ i ].onmouseover = function(){
makluman(i);
};
}

Anda akan mendapati bahawa apabila tetikus bergerak ke atas setiap elemen

Penyelesaian 1:

Salin kod Kod adalah seperti berikut:
var lists = document.getElementsByTagName('li');
for(var i = 0 , len = lists.length ; i < len ; i ){
(fungsi(indeks){
Senaraikan[indeks].onmouseover = function(){
makluman(indeks);
                                                                     })(i);
}

Penyelesaian 2:

Salin kod Kod adalah seperti berikut:

var lists = document.getElementsByTagName('li');
for(var i = 0, len = lists.length; i < len; i ){
Senaraikan[ i ].$$index = i; //Rekodkan subskrip dengan mengikat atribut $$index pada elemen Dom
Senaraikan[ i ].onmouseover = function(){
makluman(ini.$$index); };
}

Penyelesaian tiga:

Salin kod Kod adalah seperti berikut:
fungsi eventListener(senarai, indeks){
List.onmouseover = function(){
makluman(indeks);
};
}
var lists = document.getElementsByTagName('li');
for(var i = 0 , len = lists.length ; i < len ; i ){
EventListener(senarai[ i ] , i);
}

4.2 Kebocoran memori

Menggunakan penutupan boleh menyebabkan kebocoran memori dengan mudah dalam kes yang serius, penyemak imbas akan hang Jika anda berminat, anda boleh merujuk kepada:

http://www.jb51.net/article/57404. htm

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah maksud penutupan dalam ungkapan lambda C++? Apakah maksud penutupan dalam ungkapan lambda C++? Apr 17, 2024 pm 06:15 PM

Dalam C++, penutupan ialah ungkapan lambda yang boleh mengakses pembolehubah luaran. Untuk membuat penutupan, tangkap pembolehubah luar dalam ungkapan lambda. Penutupan memberikan kelebihan seperti kebolehgunaan semula, penyembunyian maklumat dan penilaian malas. Ia berguna dalam situasi dunia sebenar seperti pengendali acara, di mana penutupan masih boleh mengakses pembolehubah luar walaupun ia dimusnahkan.

Penggunaan dan ciri-ciri fungsi tanpa nama C++ Penggunaan dan ciri-ciri fungsi tanpa nama C++ Apr 19, 2024 am 09:03 AM

Fungsi tanpa nama, juga dikenali sebagai ungkapan lambda, ialah fungsi yang tidak menentukan nama dan digunakan untuk kegunaan sekali atau untuk menghantar penunjuk fungsi. Ciri termasuk: tidak mahu dikenali, penggunaan sekali sahaja, penutupan, inferens jenis pulangan. Dalam amalan, ia sering digunakan untuk mengisih atau panggilan fungsi satu masa yang lain.

Apakah kelebihan dan kekurangan penutupan dalam fungsi C++? Apakah kelebihan dan kekurangan penutupan dalam fungsi C++? Apr 25, 2024 pm 01:33 PM

Penutupan ialah fungsi bersarang yang boleh mengakses pembolehubah dalam skop fungsi luar Kelebihannya termasuk pengkapsulan data, pengekalan keadaan dan fleksibiliti. Kelemahan termasuk penggunaan memori, kesan prestasi dan kerumitan penyahpepijatan. Selain itu, penutupan boleh mencipta fungsi tanpa nama dan menyerahkannya kepada fungsi lain sebagai panggilan balik atau hujah.

Bagaimana untuk melaksanakan penutupan dalam ungkapan C++ Lambda? Bagaimana untuk melaksanakan penutupan dalam ungkapan C++ Lambda? Jun 01, 2024 pm 05:50 PM

Ungkapan C++ Lambda menyokong penutupan, yang menyimpan pembolehubah skop fungsi dan menjadikannya boleh diakses oleh fungsi. Sintaks ialah [capture-list](parameters)->return-type{function-body}. capture-list mentakrifkan pembolehubah untuk ditangkap Anda boleh menggunakan [=] untuk menangkap semua pembolehubah tempatan mengikut nilai, [&] untuk menangkap semua pembolehubah tempatan melalui rujukan, atau [variable1, variable2,...] untuk menangkap pembolehubah tertentu. Ungkapan Lambda hanya boleh mengakses pembolehubah yang ditangkap tetapi tidak boleh mengubah suai nilai asal.

Kesan penunjuk fungsi dan penutupan pada prestasi Golang Kesan penunjuk fungsi dan penutupan pada prestasi Golang Apr 15, 2024 am 10:36 AM

Kesan penunjuk fungsi dan penutupan pada prestasi Go adalah seperti berikut: Penunjuk fungsi: Lebih perlahan sedikit daripada panggilan langsung, tetapi meningkatkan kebolehbacaan dan kebolehgunaan semula. Penutupan: Biasanya lebih perlahan, tetapi merangkumi data dan tingkah laku. Kes praktikal: Penunjuk fungsi boleh mengoptimumkan algoritma pengisihan dan penutupan boleh mencipta pengendali acara, tetapi ia akan membawa kerugian prestasi.

Bagaimanakah penutupan dilaksanakan di Jawa? Bagaimanakah penutupan dilaksanakan di Jawa? May 03, 2024 pm 12:48 PM

Penutupan dalam Java membenarkan fungsi dalaman mengakses pembolehubah skop luar walaupun fungsi luar telah keluar. Dilaksanakan melalui kelas dalaman tanpa nama, kelas dalam memegang rujukan kepada kelas luar dan memastikan pembolehubah luar aktif. Penutupan meningkatkan fleksibiliti kod, tetapi anda perlu sedar tentang risiko kebocoran memori kerana rujukan kepada pembolehubah luaran oleh kelas dalaman tanpa nama memastikan pembolehubah tersebut hidup.

Panggilan berantai dan penutupan fungsi PHP Panggilan berantai dan penutupan fungsi PHP Apr 13, 2024 am 11:18 AM

Ya, kesederhanaan dan kebolehbacaan kod boleh dioptimumkan melalui panggilan berantai dan penutupan: panggilan berantai memaut fungsi panggilan ke antara muka yang lancar. Penutupan mewujudkan blok kod yang boleh digunakan semula dan pembolehubah akses di luar fungsi.

Bolehkah fungsi tanpa nama Golang mengembalikan berbilang nilai? Bolehkah fungsi tanpa nama Golang mengembalikan berbilang nilai? Apr 13, 2024 pm 04:09 PM

Ya, fungsi tanpa nama dalam bahasa Go boleh mengembalikan berbilang nilai. Sintaks: func(arg1,arg2,...,argN)(ret1,ret2,...,retM){//Function body}. Penggunaan: Gunakan operator := untuk menerima nilai pulangan menggunakan kata kunci pulangan untuk mengembalikan berbilang nilai.

See all articles