Rumah > hujung hadapan web > tutorial js > Satu lagi blog mengenai Panggil, Mohon & Ikat..!!

Satu lagi blog mengenai Panggil, Mohon & Ikat..!!

DDD
Lepaskan: 2024-11-25 09:17:11
asal
993 orang telah melayarinya

Yet another blog on Call, Apply & Bind..!!
Bla Bla Bla..

Baiklah, Dengarkan saya..!!

Beratus-ratus blog dan tutorial menerangkan panggilan, ikat dan gunakan. Malah, ChatGPT dan Copilot boleh memudahkannya untuk anda!

Jadi kenapa jawatan lain? Nah, yang ini bukan untuk _anda_ini nota diri saya semasa saya menyemak semula asas JavaScript.

Walaupun selepas 8 tahun dalam pembangunan front-end, saya kadang-kadang mencampurkan kaedah ini. Ternyata, kekeliruan sering berpunca daripada cara mereka dikumpulkan dalam soalan temu bual. Biar saya pecahkan untuk anda kali ini, dengan cara yang melekat.

Bolehkah kita melangkau ke bahagian yang baik.

Mengapa ia sentiasa memanggil, mengikat dan memohon dalam temu duga? Secara fungsional, panggil dan gunakan adalah lebih dekat mereka menggunakan fungsi dengan serta-merta manakala bind mengembalikan fungsi baharu. Itulah sebabnya saya telah mengumpulkan mereka dengan cara ini dalam tajuk.

Mari kita lihat penggunaannya untuk memahaminya dengan lebih baik.

Apakah yang biasa di kalangan Panggil, Ikat & Mohon?

call , bind , dan apply ialah kaedah yang tersedia pada fungsi yang membolehkan anda menetapkan nilai ini dan lulus secara eksplisit hujah kepada fungsi.

Apakah perbezaan antara Call, Bind & Apply?

Semasa Panggil dan Gunakan Segera menggunakan fungsi tersebut, kaedah Bind tidak akan menggunakan fungsi tersebut dengan serta-merta. sebaliknya, ia mengembalikan fungsi baharu dengan ini ditetapkan kepada nilai yang ditentukan dan fungsi yang dikembalikan ini boleh digunakan/dilaksanakan kemudian.

Apakah perbezaan antara Panggilan dan Mohon?

Sementara kedua-dua Panggil dan Guna serta-merta menggunakan fungsi dengan tersuai ini, cara mereka mengambil hujah tambahan yang membezakannya.

Semasa Call mengambil hujah individu, Apply mengambil pelbagai hujah.

Contoh

Mari lihat hujah di bawah untuk memahami penggunaan panggilan, gunakan dan ikat.

function Greetings(greeting,punctuation){
    return `${greeting} ${this.name} ${punctuation}`
}

var person = {
    name : "Nandan"
}

// Call: Immediately invokes the function with individual arguments
console.log(Greetings.call(person,"Hello","!")); // Output : Hello Nandan !

// Apply: Immediately invokes the function, but takes arguments as an array
console.log(Greetings.apply(person,["Hello","!"])); // Output : Hello Nandan !

// Bind: Returns a new function with `this` bound to the specified value
let greet = Greetings.bind(person,"Hello","!");
console.log(greet()); // Output : Hello Nandan !

//Note:
console.log(Greetings.bind(person,"Hello","!")); // Output : It will return a function
Salin selepas log masuk

Beberapa Contoh Tambahan

Menggunakan panggilan : Kaedah peminjaman daripada objek lain:

let person1 = { name: "Nandan" };
let person2 = { name: "Kumar" };

function introduce() {
    console.log(`Hi, my name is ${this.name}`);
}

introduce.call(person1); // Hi, my name is Nandan
introduce.call(person2); // Hi, my name is Kumar
Salin selepas log masuk

Menggunakan gunakan : Mencari nilai maksimum dalam tatasusunan:

let numbers = [1, 2, 3, 4, 5];
console.log(Math.max.apply(null, numbers)); // 5
Salin selepas log masuk

Menggunakan mengikat : Pengendalian acara dengan tersuai ini:

let button = document.getElementById("myButton");
let user = {
    name: "Nandan",
    greet() {
        console.log(`Hello, ${this.name}`);
    }
};

button.addEventListener("click", user.greet.bind(user));
Salin selepas log masuk

Selain itu, saya harap jadual ini akan membantu anda memahaminya dengan lebih baik.

Ciri

Pelaksanaan

Hujah

Kes Penggunaan

panggil

Melaksanakan fungsi dengan segera

Lulus secara individu

Apabila anda mengetahui hujah pada masa panggilan

mohon

Melaksanakan fungsi dengan segera

Lulus sebagai tatasusunan

Apabila hujah berada dalam tatasusunan

ikat

Mengembalikan fungsi baharu (tidak melaksanakan)

Dipraisi secara pilihan untuk fungsi baharu

Apabila anda memerlukan fungsi boleh guna semula atau prakonfigurasi

Itu sahaja, kawan-kawan! Saya harap anda mendapati nota ringkas ini tentang Panggilan, Mohon & Ikat membantu. Jika anda menikmati ini, lihat lebih banyak artikel di tapak web saya, https://nandan.dev/

Jangan ragu untuk mengulas, e-mel saya di connect@nandan.dev, atau berhubung dengan saya di Twitter, Instagram atau GitHub. Jangan lupa untuk melanggan surat berita saya untuk kemas kini tetap mengenai topik JavaScript!

Twitter | Instagram | Github | Tapak web

Atas ialah kandungan terperinci Satu lagi blog mengenai Panggil, Mohon & Ikat..!!. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:dev.to
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