Pengenalan kepada beberapa cara untuk memanggil kaedah fungsi dalam kemahiran Javascript_javascript

WBOY
Lepaskan: 2016-05-16 16:08:31
asal
1117 orang telah melayarinya

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.

Salin kod Kod adalah seperti berikut:

var a ={};
var func = function(x) {
console.log(ini);
};
a.onclick = function() {
var x = 100;
func(x);
};
a.onclick();

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.

Salin kod Kod adalah seperti berikut:

var a ={};
var func = function(x) {
console.log(ini);
};
a.onclick = function() {
var x = 100;
func.bind(this)(x); // ikat di sini
};
a.onclick();

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:

Salin kod Kod adalah seperti berikut:

a = {
func: function() {
Ini.x = 1;
          },
x: 0
};
b = {
a: a,
x: 20
};
untuk(var i = 0; i < 10; i ){
b.a.func();
}
console.log(a.x);
console.log(b.x);

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

Salin kod Kod adalah seperti berikut:

a = {
func: function() {
Ini.x = 1;
          },
x: 0
};
b = {
a: a,
x: 20
};
untuk(var i = 0; i < 10; i ){
b.a.func.call(b); // ikat ini kepada b
}
console.log(a.x);
console.log(b.x);

Berangan ini tidak dipersembahkan dengan baik, ia adalah gaya pengekodan yang mudah mengelirukan, tetapi ia tidak boleh digunakan di semua tempat.

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!