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
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
Menggunakan gunakan : Mencari nilai maksimum dalam tatasusunan:
let numbers = [1, 2, 3, 4, 5]; console.log(Math.max.apply(null, numbers)); // 5
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));
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!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza, masing -masing sesuai untuk senario aplikasi yang berbeza. Java digunakan untuk pembangunan aplikasi perusahaan dan mudah alih yang besar, sementara JavaScript digunakan terutamanya untuk pembangunan laman web.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Titik berikut harus diperhatikan apabila tarikh pemprosesan dan masa di JavaScript: 1. Terdapat banyak cara untuk membuat objek tarikh. Adalah disyorkan untuk menggunakan rentetan format ISO untuk memastikan keserasian; 2. Dapatkan dan tetapkan maklumat masa boleh diperoleh dan tetapkan kaedah, dan ambil perhatian bahawa bulan bermula dari 0; 3. Tarikh pemformatan secara manual memerlukan rentetan, dan perpustakaan pihak ketiga juga boleh digunakan; 4. Adalah disyorkan untuk menggunakan perpustakaan yang menyokong zon masa, seperti Luxon. Menguasai perkara -perkara utama ini secara berkesan dapat mengelakkan kesilapan yang sama.

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScriptispreferredforwebdevelopment, whersjavaisbetterforlarge-scalebackendsystemsandandroidapps.1) javascriptexcelsinceleatinginteractiveWebexperienceswithitsdynamicnatureanddommanipulation.2) javaoffersstrongyblectionandobjection

JavascripthassevenfundamentalDatypes: nombor, rentetan, boolean, undefined, null, objek, andsymbol.1) numberuseadouble-precisionformat, bergunaforwidevaluangesbutbecautiouswithfloating-pointarithmetic.2)

Penangkapan dan gelembung acara adalah dua peringkat penyebaran acara di Dom. Tangkap adalah dari lapisan atas ke elemen sasaran, dan gelembung adalah dari elemen sasaran ke lapisan atas. 1. Penangkapan acara dilaksanakan dengan menetapkan parameter useCapture addeventlistener kepada benar; 2. Bubble acara adalah tingkah laku lalai, useCapture ditetapkan kepada palsu atau ditinggalkan; 3. Penyebaran acara boleh digunakan untuk mencegah penyebaran acara; 4. Acara menggelegak menyokong delegasi acara untuk meningkatkan kecekapan pemprosesan kandungan dinamik; 5. Penangkapan boleh digunakan untuk memintas peristiwa terlebih dahulu, seperti pemprosesan pembalakan atau ralat. Memahami kedua -dua fasa ini membantu mengawal masa dan bagaimana JavaScript bertindak balas terhadap operasi pengguna.

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza. 1.Java adalah bahasa yang ditaip dan disusun secara statik, sesuai untuk aplikasi perusahaan dan sistem besar. 2. JavaScript adalah jenis dinamik dan bahasa yang ditafsirkan, terutamanya digunakan untuk interaksi web dan pembangunan front-end.
