cari
Rumahhujung hadapan webtutorial jsFungsi Anak Panah => Apa yang salah dengan yang biasa?

Arrow Functions => Apa yang salah dengan yang biasa? 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!

Kenyataan
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
Java vs JavaScript: Perbandingan terperinci untuk pemajuJava vs JavaScript: Perbandingan terperinci untuk pemajuMay 16, 2025 am 12:01 AM

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

Jenis data JavaScript: Adakah terdapat perbezaan antara penyemak imbas dan nodej?Jenis data JavaScript: Adakah terdapat perbezaan antara penyemak imbas dan nodej?May 14, 2025 am 12:15 AM

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.

Komen JavaScript: Panduan untuk menggunakan // dan / * * /Komen JavaScript: Panduan untuk menggunakan // dan / * * /May 13, 2025 pm 03:49 PM

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

Python vs JavaScript: Analisis Perbandingan untuk PemajuPython vs JavaScript: Analisis Perbandingan untuk PemajuMay 09, 2025 am 12:22 AM

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.

Python vs JavaScript: Memilih alat yang sesuai untuk pekerjaanPython vs JavaScript: Memilih alat yang sesuai untuk pekerjaanMay 08, 2025 am 12:10 AM

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: memahami kekuatan masing -masingPython dan javascript: memahami kekuatan masing -masingMay 06, 2025 am 12:15 AM

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.

Inti JavaScript: Adakah ia dibina di atas C atau C?Inti JavaScript: Adakah ia dibina di atas C atau C?May 05, 2025 am 12:07 AM

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

Aplikasi JavaScript: Dari Front-End ke Back-EndAplikasi JavaScript: Dari Front-End ke Back-EndMay 04, 2025 am 12:12 AM

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.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Artikel Panas

Nordhold: Sistem Fusion, dijelaskan
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

SublimeText3 Linux versi baharu

SublimeText3 Linux versi baharu

SublimeText3 Linux versi terkini

MinGW - GNU Minimalis untuk Windows

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

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)