Apa yang salah dengan yang biasa?" />
Jika anda mengembangkan pengetahuan anda tentang JavaScript dan tertanya-tanya mengapa mereka akan menambah Fungsi Anak Panah dalam ECMAScript 2015 (ES6), anda tidak bersendirian. Semasa saya membina pengetahuan saya tentang bahasa dan selok-belok dan keanehannya, saya mendapati diri saya tertanya-tanya perkara yang sama. Dalam siaran ini, saya akan membentangkan perbezaan, faedah dan sebab mengapa ia ditambah dan bila anda patut menggunakannya.
Mari bercakap perbezaan
Sebelum fungsi anak panah diperkenalkan, fungsi perlu diisytiharkan dalam format tradisional seperti di bawah:
function add(x, y) { return x + y; }
atau diisytiharkan sebagai ungkapan:
const addFunction = function add(x, y) { return x + y; }
dengan pengenalan fungsi anak panah, ini boleh ditulis sebagai:
const addFunction = (x,y) => x + y
Sintaks Ringkas
Daripada contoh di atas, kita boleh melihat dengan mudah bahawa dengan menggunakan fungsi anak panah dan memanfaatkan ciri pulangan tersiratnya, fungsi itu boleh difaktorkan semula dengan cepat kepada satu baris. Kod yang terhasil adalah lebih ringkas, bersih dan lebih mudah dibaca, menghasilkan pembangunan yang lebih lancar dan penyahpepijatan yang lebih pantas.
Mengangkat
Waktu jalan JavaScript secara lalai akan menaikkan semua fungsi dan perisytiharan berubah-ubah ke bahagian atas skopnya selepas penciptaan Konteks Pelaksanaan. Sebagai contoh, dalam skop global ini memastikan bahawa semua fungsi dan pembolehubah yang diisytiharkan akan tersedia untuk semua fungsi yang kemudiannya dipanggil. Walau bagaimanapun, fungsi anak panah tidak pernah dinaikkan, dengan itu membenarkan kawalan yang lebih besar ke atas lokasi tepat di mana fungsi dilaksanakan dan pembolehubah yang boleh diakses olehnya.
Konteks
Setiap kali fungsi JavaScript dilaksanakan, ia mencipta Konteks Perlaksanaan yang merangkumi maklumat tentang persekitaran di mana fungsi itu dijalankan, termasuk nilai ini. Walaupun fungsi tradisional dilaksanakan dalam konteksnya sendiri, fungsi anak panah akan sentiasa mewarisi konteks fungsi yang memanggilnya.
Menggunakan kod di bawah:
class Person { constructor(){ this.name = "George"; this.greetings = ["Good Morning,","Hello!","Howdy!"]; } printGreetings(){ this.greetings.forEach(function print(greet){ console.log(`${greet} ${this.name}`); }); } } let person = new Person(); person.printGreetings();
kami akan mendapat ralat mengatakan: Tidak dapat membaca sifat 'forEach' yang tidak ditentukan, ini kerana walaupun fungsi printGreetings berada dalam konteks kelas Person dan mewarisi konteksnya, namun fungsi forEach (walaupun fungsinya fungsi JavaScript terbina dalam) berjalan dalam konteksnya sendiri yang tidak mengandungi sifat this.name, oleh itu menghasilkan carian ralat.
Walau bagaimanapun, fungsi anak panah tidak akan berjalan dalam konteksnya sendiri dan dengan menulis semula fungsi di atas menggunakan fungsi anak panah...
printGreetings(){ this.greetings.forEach((greet) => { console.log(`${greet} ${this.name}`); }); }
hasilnya akan seperti yang diharapkan
function add(x, y) { return x + y; }
Ringkasan
Untuk meringkaskan faedah fungsi anak panah; mereka membenarkan kod yang lebih pendek dan ringkas; menawarkan pengembalian tersirat kod blok fungsi; tidak mengangkat ke bahagian atas Konteks Pelaksanaan dan mengekalkan lokasi tepatnya dalam kod; akhirnya, mereka mewarisi konteks fungsi yang memanggilnya tanpa melaksanakan konteksnya sendiri, membenarkan penggunaan kata kunci ini yang lebih boleh diramal.
Semoga siaran ini membantu anda memahami dengan lebih baik perbezaan dan faedah fungsi tradisional, ayat-ayat anak panah, dan membawa anda selangkah lebih jauh dalam perjalanan JavaScript anda!
Bacaan lanjut:
Blog Dmitri Pavlutin - Perbezaan antara anak panah & fungsi biasa
Dokumen Rujukan MDN - Fungsi Anak Panah
Atas ialah kandungan terperinci Fungsi Anak Panah => Apa yang salah dengan yang biasa?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

JavaandjavascriptaredistinctLanguages: javaisusedforenterpriseandMobileApps, whilvascriptisforinteractivewebpages.1) javaisco mpiled, statiktyped, andrunsonjvm.2) javascriptisinterinterpreted, dinamicallytyped, andrunsinbrowsersornode.js.3) javausesoopwithcl

Jenis data teras JavaScript adalah konsisten dalam penyemak imbas dan node.js, tetapi ditangani secara berbeza dari jenis tambahan. 1) Objek global adalah tetingkap dalam penyemak imbas dan global di Node.js. 2) Objek penampan unik Node.js, digunakan untuk memproses data binari. 3) Terdapat juga perbezaan prestasi dan pemprosesan masa, dan kod perlu diselaraskan mengikut persekitaran.

JavaScriptusestWotypesofcomments: Single-line (//) danMulti-line (//)

Perbezaan utama antara Python dan JavaScript ialah sistem jenis dan senario aplikasi. 1. Python menggunakan jenis dinamik, sesuai untuk pengkomputeran saintifik dan analisis data. 2. JavaScript mengamalkan jenis yang lemah dan digunakan secara meluas dalam pembangunan depan dan stack penuh. Kedua -duanya mempunyai kelebihan mereka sendiri dalam pengaturcaraan dan pengoptimuman prestasi yang tidak segerak, dan harus diputuskan mengikut keperluan projek ketika memilih.

Sama ada untuk memilih Python atau JavaScript bergantung kepada jenis projek: 1) Pilih Python untuk Sains Data dan Tugas Automasi; 2) Pilih JavaScript untuk pembangunan front-end dan penuh. Python disukai untuk perpustakaannya yang kuat dalam pemprosesan data dan automasi, sementara JavaScript sangat diperlukan untuk kelebihannya dalam interaksi web dan pembangunan stack penuh.

Python dan JavaScript masing -masing mempunyai kelebihan mereka sendiri, dan pilihan bergantung kepada keperluan projek dan keutamaan peribadi. 1. Python mudah dipelajari, dengan sintaks ringkas, sesuai untuk sains data dan pembangunan back-end, tetapi mempunyai kelajuan pelaksanaan yang perlahan. 2. JavaScript berada di mana-mana dalam pembangunan front-end dan mempunyai keupayaan pengaturcaraan tak segerak yang kuat. Node.js menjadikannya sesuai untuk pembangunan penuh, tetapi sintaks mungkin rumit dan rawan kesilapan.

Javascriptisnotbuiltoncorc; it'saninterpretedlanguagethatrunsonenginesoftenwritteninc .1) javascriptwasdesignedasalightweight, interpratedlanguageforwebbrowsers.2)

JavaScript boleh digunakan untuk pembangunan front-end dan back-end. Bahagian depan meningkatkan pengalaman pengguna melalui operasi DOM, dan back-end mengendalikan tugas pelayan melalui Node.js. 1. Contoh front-end: Tukar kandungan teks laman web. 2. Contoh backend: Buat pelayan Node.js.


Alat AI Hot

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

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

Undress AI Tool
Gambar buka pakaian secara percuma

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

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)
