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

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

Nov 25, 2024 am 09:17 AM

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!

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

Tag artikel 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)

Ganti aksara rentetan dalam javascript Ganti aksara rentetan dalam javascript Mar 11, 2025 am 12:07 AM

Ganti aksara rentetan dalam javascript

jQuery mendapatkan padding/margin elemen jQuery mendapatkan padding/margin elemen Mar 01, 2025 am 08:53 AM

jQuery mendapatkan padding/margin elemen

periksa jQuery jika tarikh sah periksa jQuery jika tarikh sah Mar 01, 2025 am 08:51 AM

periksa jQuery jika tarikh sah

10 Tab Accordion JQuery 10 Tab Accordion JQuery Mar 01, 2025 am 01:34 AM

10 Tab Accordion JQuery

10 patut diperiksa plugin jQuery 10 patut diperiksa plugin jQuery Mar 01, 2025 am 01:29 AM

10 patut diperiksa plugin jQuery

Tutorial Persediaan API Carian Google Custom Tutorial Persediaan API Carian Google Custom Mar 04, 2025 am 01:06 AM

Tutorial Persediaan API Carian Google Custom

HTTP Debugging dengan Node dan HTTP-Console HTTP Debugging dengan Node dan HTTP-Console Mar 01, 2025 am 01:37 AM

HTTP Debugging dengan Node dan HTTP-Console

jQuery tambah bar scroll ke div jQuery tambah bar scroll ke div Mar 01, 2025 am 01:30 AM

jQuery tambah bar scroll ke div

See all articles