Jadual Kandungan
1. Apakah itu penutupan
2. Kelebihan, keburukan dan ciri penutupan dalam JS
3. Skop pembolehubah
4. Tafsirkan penutupan dengan kod
五、如何从外部读取函数内部的局部变量?
六、闭包的用途
七、使用闭包的注意点
八、总结:
Rumah hujung hadapan web Soal Jawab bahagian hadapan Apakah penutupan dalam javascript

Apakah penutupan dalam javascript

Oct 18, 2021 am 11:59 AM
javascript penutupan

Dalam JavaScript, apabila dua fungsi bersarang antara satu sama lain, fungsi dalaman ialah penutupan. Penutupan ialah fungsi yang mempunyai akses kepada pembolehubah dalam skop fungsi lain Cara yang paling biasa untuk membuat penutupan ialah mencipta fungsi lain dalam fungsi dan mengakses pembolehubah tempatan fungsi ini melalui fungsi lain.

Apakah penutupan dalam javascript

Persekitaran pengendalian tutorial ini: sistem Windows 7, versi JavaScript 1.8.5, komputer Dell G3.

1. Apakah itu penutupan

Penutupan ialah fungsi yang boleh membaca pembolehubah dalaman fungsi lain. Dalam JavaScript, hanya subfungsi dalam fungsi boleh membaca pembolehubah setempat, jadi penutupan boleh difahami sebagai "fungsi yang ditakrifkan dalam fungsi." Pada dasarnya, penutupan ialah jambatan antara bahagian dalam fungsi dan bahagian luar fungsi. (Aplikasi penutupan yang paling tipikal adalah untuk melaksanakan fungsi panggil balik).

2. Kelebihan, keburukan dan ciri penutupan dalam JS

Kelebihan:

1 , Lindungi keselamatan pembolehubah dalam fungsi

2. Kekalkan pembolehubah dalam ingatan (menggunakan terlalu banyak akan menjadi kelemahan dan menduduki memori

3. Kesinambungan logik, apabila ditutup Apabila digunakan sebagai parameter dalam panggilan fungsi lain, ia menghalang anda daripada menulis logik tambahan secara berasingan daripada logik semasa.

4. Pembolehubah setempat yang memudahkan konteks panggilan.

5. Mengukuhkan enkapsulasi boleh mencapai perlindungan pembolehubah.

Kelemahan:

1. Memori residen akan meningkatkan penggunaan memori dengan mudah menyebabkan kebocoran memori.
2. Terdapat juga masalah yang sangat serius, iaitu masalah sisa ingatan ini bukan sahaja kerana ia berada dalam ingatan, tetapi yang lebih penting, penggunaan penutupan yang tidak betul akan menyebabkan penjanaan ingatan tidak sah.

Ciri:

1. Fungsi bersarang fungsi

2. Fungsi dalaman boleh mengakses pembolehubah fungsi luaran

3. Parameter dan pembolehubah tidak akan dikitar semula.

3. Skop pembolehubah

Untuk memahami penutupan, tidak cukup dengan memahami konsep penutupan di atas sahaja. Pertama, anda mesti memahami skop pembolehubah khas JavaScript.

1. Hanya terdapat dua skop pembolehubah: pembolehubah global dan pembolehubah tempatan.

2. Keistimewaan bahasa JavaScript ialah pembolehubah global boleh dibaca terus di dalam fungsi, tetapi pembolehubah tempatan di dalam fungsi tidak boleh dibaca di luar fungsi.

3. Nota: Apabila mengisytiharkan pembolehubah di dalam fungsi, pastikan anda menggunakan arahan var. Jika anda tidak menggunakannya, anda sebenarnya mengisytiharkan pembolehubah global!

4. Tafsirkan penutupan dengan kod

Proses penciptaan penutupan dalam Javascript adalah seperti yang ditunjukkan dalam program berikut.

function a () {
   var i = 0;
   function b () {
      alert (i++);
   }
  return b;
}
var c = a();
c();  //函数调用
Salin selepas log masuk

Ciri Kod

Kod ini mempunyai dua ciri:

1. Fungsi b bersarang dalam fungsi Dalam a;

2. Fungsi a mengembalikan fungsi b.

Dengan cara ini, selepas melaksanakan var c = a(), pembolehubah c sebenarnya menunjuk ke fungsi b Selepas melaksanakan c() sekali lagi, tetingkap akan muncul untuk memaparkan nilai i (kali pertama ialah 1) . Kod ini sebenarnya mencipta penutupan kerana pembolehubah c fungsi luar a merujuk kepada fungsi b dalam fungsi a. Dalam erti kata lain, apabila fungsi b dalam fungsi a dirujuk oleh pembolehubah di luar fungsi a, penutupan dibuat.

Fungsi

Ringkasnya, fungsi penutupan adalah untuk membolehkan kutipan sampah Javascript selepas a dilaksanakan dan dipulangkan sumber yang diduduki oleh a, kerana pelaksanaan fungsi dalaman a b perlu bergantung pada pembolehubah dalam a.

Dalam contoh di atas, disebabkan kewujudan penutupan, i dalam a akan sentiasa wujud selepas fungsi a kembali Dengan cara ini, setiap kali c() dilaksanakan, i akan menjadi nilai i iaitu dimaklumkan selepas menambah 1. .

Kemudian mari bayangkan situasi lain Jika a mengembalikan sesuatu selain daripada fungsi b, keadaannya berbeza sama sekali. Kerana selepas a dilaksanakan, b tidak dikembalikan ke dunia luar a, tetapi hanya dirujuk oleh a Pada masa ini, a hanya akan dirujuk oleh b. Oleh itu, fungsi a dan b merujuk antara satu sama lain tetapi tidak terganggu oleh dunia luar (dirujuk oleh dunia luar , fungsi a dan b akan dikitar semula).

Senario Aplikasi

1 Lindungi pembolehubah dalam fungsi. Dalam fungsi a, i hanya boleh diakses oleh fungsi b dan tidak boleh diakses melalui cara lain, sekali gus melindungi keselamatan i.

2. Kekalkan pembolehubah dalam ingatan. Oleh kerana penutupan, i dalam fungsi a sentiasa wujud dalam ingatan, jadi setiap kali c() dilaksanakan, i akan dinaikkan sebanyak 1.

五、如何从外部读取函数内部的局部变量?

  出于种种原因,我们有时候需要获取到函数内部的局部变量。但是,上面(三、变量作用域)已经说过了,正常情况下,这是办不到的!只有通过变通的方法才能实现。那就是在函数内部,再定义一个函数。

function demo1 () {
    var n = 6699;
    function demo2 () {
      alert(n); // 6699
    }
  }
Salin selepas log masuk

在上面的代码中,函数 demo2 就被包括在函数demo1内部,这时demo1内部的所有局部变量,对demo2都是可见的。但是反过来就不行,demo2内部的局部变量,对demo1就是不可见的。 

这就是Javascript语言特有的”链式作用域”结构(chain scope),子对象会一级一级地向上寻找所有父对象的变量。所以,父对象的所有变量,对子对象都是可见的,反之则不成立。 

既然demo2可以读取demo1中的局部变量,那么只要把demo2作为返回值,我们不就可以在demo1外部读取它的内部变量了吗!

六、闭包的用途

闭包可以用在许多地方。它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中,不会在demo1调用后被自动清除。 

那为什么会这样呢?原因就在于demo1是demo2的父函数,而demo2被赋给了一个全局变量,这导致demo2始终在内存中,而demo2的存在依赖于demo1,因此demo1也始终在内存中,不会在调用结束后,被垃圾回收机制(garbage collection)回收。

七、使用闭包的注意点

1、由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。 

2、闭包会在父函数外部,改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。

八、总结:

1、闭包是指有权访问另一个函数作用域中的变量的函数,创建闭包的最常见的方式就是在一个函数内创建另一个函数,通过另一个函数访问这个函数的局部变量。闭包的缺点就是常驻内存,会增大内存使用量,使用不当很容易造成内存泄露。 

2、不适合场景:返回闭包的函数是个非常大的函数。 

    闭包的典型框架应该就是jquery了。 

    闭包是javascript语言的一大特点,主要应用闭包场合主要是为了:设计私有的方法和变量。 

    这在做框架的时候体现更明显,有些方法和属性只是运算逻辑过程中的使用的,不想让外部修改这些属性,因此就可以设计一个闭包来只提供方法获取。 

3、 不必纠结到底怎样才算闭包,其实你写的每一个函数都算作闭包,即使是全局函数,你访问函数外部的全局变量时,就是闭包
的体现。

更多编程相关知识,请访问:编程入门!!

Atas ialah kandungan terperinci Apakah penutupan dalam javascript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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.

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.

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.

Selesaikan masalah kebocoran memori yang disebabkan oleh penutupan Selesaikan masalah kebocoran memori yang disebabkan oleh penutupan Feb 18, 2024 pm 03:20 PM

Tajuk: Kebocoran memori disebabkan oleh penutupan dan penyelesaian Pengenalan: Penutupan ialah konsep yang sangat biasa dalam JavaScript, yang membenarkan fungsi dalaman mengakses pembolehubah fungsi luaran. Walau bagaimanapun, penutupan boleh menyebabkan kebocoran memori jika digunakan secara tidak betul. Artikel ini akan meneroka masalah kebocoran memori yang disebabkan oleh penutupan dan menyediakan penyelesaian serta contoh kod khusus. 1. Kebocoran memori disebabkan oleh penutupan Ciri penutupan ialah fungsi dalaman boleh mengakses pembolehubah fungsi luaran, yang bermaksud pembolehubah yang dirujuk dalam penutupan tidak akan dikumpul sampah. Jika digunakan secara tidak betul,

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.

Ringkasan kelebihan dan kekurangan fungsi dan penutupan tanpa nama golang Ringkasan kelebihan dan kekurangan fungsi dan penutupan tanpa nama golang May 05, 2024 am 09:54 AM

Fungsi tanpa nama adalah ringkas dan tanpa nama, tetapi mempunyai kebolehbacaan yang lemah dan kesukaran dalam penyahpepijatan boleh merangkum data dan mengurus keadaan, tetapi boleh menyebabkan penggunaan memori dan rujukan bulat. Kes praktikal: Fungsi tanpa nama boleh digunakan untuk pemprosesan berangka yang mudah, dan penutupan boleh melaksanakan pengurusan negeri.

See all articles