Rumah  >  Artikel  >  hujung hadapan web  >  Bercakap tentang pemahaman saya tentang prototaip JavaScript dan siri penutupan (nota rawak 6)_kemahiran javascript

Bercakap tentang pemahaman saya tentang prototaip JavaScript dan siri penutupan (nota rawak 6)_kemahiran javascript

WBOY
WBOYasal
2016-05-16 15:24:391209semak imbas

Bacaan berkaitan: Bercakap tentang pemahaman saya tentang prototaip JavaScript dan siri penutupan (Shuishou Note 8)

Apakah itu penutupan

Apakah itu penutupan? Penutupan ialah Penutupan, iaitu ciri baharu yang tidak ada pada bahasa statik. Tetapi penutupan bukanlah sesuatu yang terlalu rumit untuk difahami Secara ringkasnya, penutupan ialah:

• Penutupan ialah koleksi pembolehubah tempatan sesuatu fungsi, tetapi pembolehubah tempatan ini akan terus wujud selepas fungsi itu kembali.

• Penutupan bermaksud bahawa "timbunan" fungsi tidak dikeluarkan selepas fungsi itu kembali. Kita juga boleh memahami bahawa timbunan fungsi ini tidak diperuntukkan pada timbunan tetapi pada timbunan

• Apabila mentakrifkan fungsi lain dalam fungsi, penutupan akan dijana

Apakah prototaip?

Prototaip ialah objek yang melaluinya objek lain boleh melaksanakan pewarisan harta.

Bolehkah mana-mana objek menjadi prototaip?

Ya

Objek yang manakah mempunyai prototaip

Semua objek mempunyai prototaip secara lalai, kerana prototaip itu sendiri juga merupakan objek, jadi setiap prototaip itu sendiri mempunyai prototaip (dengan satu pengecualian, prototaip objek lalai berada di bahagian atas rantai prototaip >).

Konteks pelaksanaan
Setiap kali pengawal bertukar kepada kod boleh laku ECMAScript, ia memasuki konteks pelaksanaan.


Konteks pelaksanaan (pendek kata EC) ialah konsep abstrak Piawaian ECMA-262 menggunakan konsep ini untuk membezakannya daripada konsep kod boleh laku.

Spesifikasi standard tidak mentakrifkan jenis dan struktur EC dengan tepat dari perspektif pelaksanaan teknikal ini harus menjadi isu yang perlu dipertimbangkan apabila melaksanakan enjin ECMAScript secara khusus.

Konteks pelaksanaan aktiviti secara logiknya membentuk timbunan. Bahagian bawah tindanan sentiasa konteks global, dan bahagian atas tindanan ialah konteks pelaksanaan semasa (aktif). Tindanan diubah suai apabila pelbagai raja EC ditolak atau muncul.


------------------------------------------------ --- -----------------------------------

Situasi 1:

Sebelum mengambil sekeping kod js dan benar-benar menjalankannya ayat demi ayat, penyemak imbas telah melakukan beberapa "kerja persediaan", yang termasuk mengisytiharkan pembolehubah dan bukannya memberikan nilai. Tugasan pembolehubah dilakukan apabila pernyataan tugasan dilaksanakan.

Kes 2:

Dalam peringkat "persediaan", ini diberikan secara langsung.

console.log(this) //Tetingkap



Kes 3:

Fungsi: ungkapan fungsi dan pengisytiharan fungsi

 console.log(f1); //function f1() {}
function f1() {} //函数声明
console.log(f2); //undefined
var f2 = function() {}; //函数表达式 
Ringkasan “Persediaan”:


•Pembolehubah, ungkapan fungsi————Pengisytiharan pembolehubah, tugasan lalai tidak ditentukan


•ini————tugasan


•Pengisytiharan fungsi————Tugasan


Kami memanggil penyediaan ketiga-tiga jenis data ini sebagai "konteks pelaksanaan" atau "persekitaran konteks pelaksanaan".


------------------------------------------------ --- -----------------------------------

Sebelum JavaScript melaksanakan segmen kod, ia akan melaksanakan "kerja persediaan" ini untuk menjana konteks pelaksanaan. "Segmen kod" ini dibahagikan kepada tiga situasi-kod global, kod fungsi dan kod Eval.

 //全局代码段
<script type="text/javascript">
 //代码段...
</script>
//函数代码段
function fn(x) {
 console.log(x + 5);
}
var fn = new Function("x", "console.log(x + 5)");
//Eval代码段
eval('var x = 10');
(function foo() {
 eval('var y = 20');
})();
alert(x); //10
alert(y); //"y" is not defined
//因为eval涉及到安全问题(脚本注入),所以尽量不用。 
------------------------------------------------ --- -----------------------------------

Dalam fungsi, sebagai tambahan kepada beberapa situasi "persediaan", terdapat juga data lain

 function fn(x) {
 console.log(arguments); //[10]
 conosole.log(x); //10
}
fn(10); 
Kod di atas menunjukkan bahawa pembolehubah argumen dan parameter fungsi telah ditetapkan sebelum pernyataan dalam badan fungsi dilaksanakan.


Setiap kali fungsi dipanggil, persekitaran pelaksanaan konteks baharu akan dijana. Kerana panggilan yang berbeza mungkin menghasilkan parameter yang berbeza.


Skop pembolehubah bebas di dalam badan fungsi telah ditentukan apabila fungsi ditakrifkan (tidak dipanggil).

Ringkasan:

Kandungan data konteks kod global ialah:

•Pembolehubah biasa (termasuk ungkapan fungsi), seperti: var a = 10 | ===>

•Pengisytiharan fungsi, seperti fungsi fn() {} |


•ini |. ===>


Badan berfungsi

•Parameter |. ===>

•hujah |. ===>


•Skop nilai pembolehubah bebas |

Definisi popular:

Sebelum melaksanakan kod, keluarkan semua pembolehubah yang akan digunakan lebih awal Ada yang ditetapkan secara langsung dan ada yang diduduki oleh undefined dahulu.

Kandungan di atas ialah keseluruhan perihalan prototaip JavaScript dan pemahaman siri penutupan (nota rawak 6) yang dikongsi oleh editor dengan anda.

Kenyataan:
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