Rumah hujung hadapan web tutorial js Panduan Komprehensif untuk Fungsi Anak Panah ESnd

Panduan Komprehensif untuk Fungsi Anak Panah ESnd

Oct 03, 2024 pm 10:25 PM

A Comprehensive Guide to ESnd Arrow Functions

Pengenalan kepada ES6

ECMAScript 2015, juga dikenali sebagai ES6 (ECMAScript 6), ialah kemas kini penting kepada JavaScript, memperkenalkan sintaks dan ciri baharu yang menjadikan pengekodan lebih cekap dan lebih mudah untuk diurus. JavaScript ialah salah satu bahasa pengaturcaraan paling popular yang digunakan untuk pembangunan web dan penambahbaikan dalam ES6 meningkatkan keupayaannya.

Panduan ini akan merangkumi ciri-ciri penting yang diperkenalkan dalam ES6, dengan tumpuan khas pada Fungsi Anak Panah, satu cara baru untuk menulis fungsi.

Ciri-ciri Utama ES6

1. biar dan const

ES6 memperkenalkan dua cara baharu untuk mengisytiharkan pembolehubah: let dan const.

  • biar: Mengisytiharkan pembolehubah berskop blok, bermakna pembolehubah hanya tersedia dalam blok yang diisytiharkan.

     let x = 10;
     if (true) {
       let x = 2;
       console.log(x); // 2 (inside block)
     }
     console.log(x); // 10 (outside block)
    
    Salin selepas log masuk
  • const: Mengisytiharkan pembolehubah malar yang tidak boleh ditugaskan semula. Walau bagaimanapun, ini tidak menjadikan pembolehubah tidak berubah—objek yang diisytiharkan dengan const masih boleh menukar sifatnya.

     const y = 10;
     y = 5; // Error: Assignment to constant variable.
    
     const person = { name: "John", age: 30 };
     person.age = 31; // This is allowed.
    
    Salin selepas log masuk

2. Fungsi Anak Panah

Salah satu ciri ES6 yang paling banyak diperkatakan ialah Fungsi Anak Panah. Ia menyediakan sintaks yang lebih pendek dan ringkas untuk fungsi penulisan.

#### Perbandingan Sintaks:

Fungsi Tradisional (ES5):

   var add = function(x, y) {
     return x + y;
   };
Salin selepas log masuk

Fungsi Anak Panah (ES6):

   const add = (x, y) => x + y;
Salin selepas log masuk

Inilah yang menjadikan Fungsi Anak Panah berbeza:

  • Sintaks yang lebih pendek: Anda tidak perlu menulis kata kunci fungsi dan anda boleh menghilangkan kurungan kerinting {} jika fungsi itu mempunyai satu pernyataan.
  • Pulangan tersirat: Jika fungsi mengandungi hanya satu ungkapan, hasil ungkapan itu dikembalikan secara automatik.
  • Tiada pengikatan ini: Fungsi anak panah tidak mempunyai ini sendiri, menjadikannya tidak sesuai untuk kaedah objek.

Contoh fungsi anak panah satu baris:

   const multiply = (a, b) => a * b;
   console.log(multiply(4, 5)); // 20
Salin selepas log masuk

Fungsi anak panah juga boleh digunakan tanpa parameter:

   const greet = () => "Hello, World!";
   console.log(greet()); // "Hello, World!"
Salin selepas log masuk

Untuk fungsi dengan lebih daripada satu baris, pendakap kerinting {} diperlukan dan pernyataan pulangan mestilah eksplisit:

   const sum = (a, b) => {
     let result = a + b;
     return result;
   };
Salin selepas log masuk

Fungsi Anak Panah dan ini
Satu perbezaan penting ialah cara ini berkelakuan dalam Fungsi Anak Panah. Tidak seperti fungsi tradisional, Fungsi Anak Panah tidak mengikat ini sendiri—mereka mewarisi ini daripada konteks sekelilingnya.

   const person = {
     name: "John",
     sayName: function() {
       setTimeout(() => {
         console.log(this.name);
       }, 1000);
     }
   };
   person.sayName(); // "John"
Salin selepas log masuk

Dalam contoh di atas, Fungsi Anak Panah di dalam setTimeout mewarisi ini daripada kaedah sayName, yang merujuk kepada objek orang dengan betul.

3. Memusnahkan Tugasan

Pemusnahan membolehkan kami mengekstrak nilai daripada tatasusunan atau objek dan menetapkannya kepada pembolehubah dengan cara yang lebih ringkas.

Pemusnahan Objek:

   const person = { name: "John", age: 30 };
   const { name, age } = person;
   console.log(name); // "John"
   console.log(age);  // 30
Salin selepas log masuk

Pemusnahan Tatasusunan:

   const fruits = ["Apple", "Banana", "Orange"];
   const [first, second] = fruits;
   console.log(first);  // "Apple"
   console.log(second); // "Banana"
Salin selepas log masuk

4. Operator Hamparan dan Rehat (...)

Pengendali ... boleh digunakan untuk mengembangkan tatasusunan menjadi elemen individu atau untuk mengumpulkan berbilang elemen ke dalam tatasusunan.

  • Sebarkan: Kembangkan tatasusunan kepada elemen individu.

     const numbers = [1, 2, 3];
     const newNumbers = [...numbers, 4, 5];
     console.log(newNumbers); // [1, 2, 3, 4, 5]
    
    Salin selepas log masuk
  • Rehat: Mengumpul berbilang argumen ke dalam tatasusunan.

     function sum(...args) {
       return args.reduce((acc, curr) => acc + curr);
     }
     console.log(sum(1, 2, 3, 4)); // 10
    
    Salin selepas log masuk

5. Janji

Janji digunakan untuk mengendalikan operasi tak segerak dalam JavaScript. Janji mewakili nilai yang mungkin tersedia sekarang, pada masa hadapan, atau tidak sama sekali.

Contoh:

   const myPromise = new Promise((resolve, reject) => {
     setTimeout(() => {
       resolve("Success!");
     }, 1000);
   });

   myPromise.then(result => {
     console.log(result); // "Success!" after 1 second
   });
Salin selepas log masuk

Dalam contoh ini, promise diselesaikan selepas 1 saat dan kaedah then() mengendalikan nilai yang diselesaikan.

6. Parameter Lalai

Dalam ES6, anda boleh menetapkan nilai lalai untuk parameter fungsi. Ini berguna apabila parameter tidak disediakan atau tidak ditentukan.

Contoh:

   function greet(name = "Guest") {
     return `Hello, ${name}!`;
   }
   console.log(greet());       // "Hello, Guest!"
   console.log(greet("John")); // "Hello, John!"
Salin selepas log masuk

7. Kaedah Rentetan (termasuk(), startsWith(), endsWith())

Kaedah baharu telah ditambahkan pada rentetan untuk memudahkan tugasan biasa:

  • termasuk(): Menyemak sama ada rentetan mengandungi nilai yang ditentukan.

     let str = "Hello world!";
     console.log(str.includes("world")); // true
    
    Salin selepas log masuk
  • startsWith(): Menyemak sama ada rentetan bermula dengan nilai yang ditentukan.

     console.log(str.startsWith("Hello")); // true
    
    Salin selepas log masuk
  • endsWith(): Menyemak sama ada rentetan berakhir dengan nilai yang ditentukan.

     console.log(str.endsWith("!")); // true
    
    Salin selepas log masuk

8. Kaedah Tatasusunan (cari(), findIndex(), daripada())

ES6 memperkenalkan kaedah baharu untuk bekerja dengan tatasusunan:

  • find(): Mengembalikan elemen pertama yang memenuhi syarat.

     const numbers = [5, 12, 8, 130, 44];
     const found = numbers.find(num => num > 10);
     console.log(found); // 12
    
    Salin selepas log masuk
  • findIndex(): Mengembalikan indeks elemen pertama yang memenuhi syarat.

     const index = numbers.findIndex(num => num > 10);
     console.log(index); // 1 (position of 12 in the array)
    
    Salin selepas log masuk

9. Classes

ES6 introduced classes to JavaScript, which are syntactical sugar over JavaScript’s existing prototype-based inheritance. Classes allow for cleaner and more understandable object-oriented programming.

Example:

   class Car {
     constructor(brand, year) {
       this.brand = brand;
       this.year = year;
     }

     displayInfo() {
       return `${this.brand} from ${this.year}`;
     }
   }

   const myCar = new Car("Toyota", 2020);
   console.log(myCar.displayInfo()); // "Toyota from 2020"
Salin selepas log masuk

Conclusion

ES6 has transformed JavaScript, making it more efficient and easier to use. The introduction of Arrow Functions simplifies function syntax, while new features like destructuring, promises, classes, and the spread operator allow developers to write cleaner, more expressive code. Whether you are a beginner or an advanced developer, understanding these ES6 features is essential for writing modern JavaScript.

By mastering these concepts, you’ll be better equipped to handle real-world coding challenges and build efficient, scalable web applications.

Follow up with Arrow Functions project on GitHub

References

  • https://www.w3schools.com/js/js_es6.asp
  • https://towardsdatascience.com/javascript-es6-iterables-and-iterators-de18b54f4d4
  • https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/rest_parameters
  • https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Default_parameters
  • https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions
  • https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements

Atas ialah kandungan terperinci Panduan Komprehensif untuk Fungsi Anak Panah ESnd. 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

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

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat 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)

Topik panas

Tutorial Java
1672
14
Tutorial PHP
1276
29
Tutorial C#
1256
24
Python vs JavaScript: Keluk Pembelajaran dan Kemudahan Penggunaan Python vs JavaScript: Keluk Pembelajaran dan Kemudahan Penggunaan Apr 16, 2025 am 12:12 AM

Python lebih sesuai untuk pemula, dengan lengkung pembelajaran yang lancar dan sintaks ringkas; JavaScript sesuai untuk pembangunan front-end, dengan lengkung pembelajaran yang curam dan sintaks yang fleksibel. 1. Sintaks Python adalah intuitif dan sesuai untuk sains data dan pembangunan back-end. 2. JavaScript adalah fleksibel dan digunakan secara meluas dalam pengaturcaraan depan dan pelayan.

JavaScript dan Web: Fungsi teras dan kes penggunaan JavaScript dan Web: Fungsi teras dan kes penggunaan Apr 18, 2025 am 12:19 AM

Penggunaan utama JavaScript dalam pembangunan web termasuk interaksi klien, pengesahan bentuk dan komunikasi tak segerak. 1) kemas kini kandungan dinamik dan interaksi pengguna melalui operasi DOM; 2) pengesahan pelanggan dijalankan sebelum pengguna mengemukakan data untuk meningkatkan pengalaman pengguna; 3) Komunikasi yang tidak bersesuaian dengan pelayan dicapai melalui teknologi Ajax.

JavaScript in Action: Contoh dan projek dunia nyata JavaScript in Action: Contoh dan projek dunia nyata Apr 19, 2025 am 12:13 AM

Aplikasi JavaScript di dunia nyata termasuk pembangunan depan dan back-end. 1) Memaparkan aplikasi front-end dengan membina aplikasi senarai TODO, yang melibatkan operasi DOM dan pemprosesan acara. 2) Membina Restfulapi melalui Node.js dan menyatakan untuk menunjukkan aplikasi back-end.

Memahami Enjin JavaScript: Butiran Pelaksanaan Memahami Enjin JavaScript: Butiran Pelaksanaan Apr 17, 2025 am 12:05 AM

Memahami bagaimana enjin JavaScript berfungsi secara dalaman adalah penting kepada pemaju kerana ia membantu menulis kod yang lebih cekap dan memahami kesesakan prestasi dan strategi pengoptimuman. 1) aliran kerja enjin termasuk tiga peringkat: parsing, penyusun dan pelaksanaan; 2) Semasa proses pelaksanaan, enjin akan melakukan pengoptimuman dinamik, seperti cache dalam talian dan kelas tersembunyi; 3) Amalan terbaik termasuk mengelakkan pembolehubah global, mengoptimumkan gelung, menggunakan const dan membiarkan, dan mengelakkan penggunaan penutupan yang berlebihan.

Python vs JavaScript: Komuniti, Perpustakaan, dan Sumber Python vs JavaScript: Komuniti, Perpustakaan, dan Sumber Apr 15, 2025 am 12:16 AM

Python dan JavaScript mempunyai kelebihan dan kekurangan mereka sendiri dari segi komuniti, perpustakaan dan sumber. 1) Komuniti Python mesra dan sesuai untuk pemula, tetapi sumber pembangunan depan tidak kaya dengan JavaScript. 2) Python berkuasa dalam bidang sains data dan perpustakaan pembelajaran mesin, sementara JavaScript lebih baik dalam perpustakaan pembangunan dan kerangka pembangunan depan. 3) Kedua -duanya mempunyai sumber pembelajaran yang kaya, tetapi Python sesuai untuk memulakan dengan dokumen rasmi, sementara JavaScript lebih baik dengan MDNWebDocs. Pilihan harus berdasarkan keperluan projek dan kepentingan peribadi.

Python vs JavaScript: Persekitaran dan Alat Pembangunan Python vs JavaScript: Persekitaran dan Alat Pembangunan Apr 26, 2025 am 12:09 AM

Kedua -dua pilihan Python dan JavaScript dalam persekitaran pembangunan adalah penting. 1) Persekitaran pembangunan Python termasuk Pycharm, Jupyternotebook dan Anaconda, yang sesuai untuk sains data dan prototaip cepat. 2) Persekitaran pembangunan JavaScript termasuk node.js, vscode dan webpack, yang sesuai untuk pembangunan front-end dan back-end. Memilih alat yang betul mengikut keperluan projek dapat meningkatkan kecekapan pembangunan dan kadar kejayaan projek.

Peranan C/C dalam JavaScript Jurubah dan Penyusun Peranan C/C dalam JavaScript Jurubah dan Penyusun Apr 20, 2025 am 12:01 AM

C dan C memainkan peranan penting dalam enjin JavaScript, terutamanya digunakan untuk melaksanakan jurubahasa dan penyusun JIT. 1) C digunakan untuk menghuraikan kod sumber JavaScript dan menghasilkan pokok sintaks abstrak. 2) C bertanggungjawab untuk menjana dan melaksanakan bytecode. 3) C melaksanakan pengkompil JIT, mengoptimumkan dan menyusun kod hot-spot semasa runtime, dan dengan ketara meningkatkan kecekapan pelaksanaan JavaScript.

Dari laman web ke aplikasi: Aplikasi pelbagai JavaScript Dari laman web ke aplikasi: Aplikasi pelbagai JavaScript Apr 22, 2025 am 12:02 AM

JavaScript digunakan secara meluas di laman web, aplikasi mudah alih, aplikasi desktop dan pengaturcaraan sisi pelayan. 1) Dalam pembangunan laman web, JavaScript mengendalikan DOM bersama -sama dengan HTML dan CSS untuk mencapai kesan dinamik dan menyokong rangka kerja seperti JQuery dan React. 2) Melalui reaktnatif dan ionik, JavaScript digunakan untuk membangunkan aplikasi mudah alih rentas platform. 3) Rangka kerja elektron membolehkan JavaScript membina aplikasi desktop. 4) Node.js membolehkan JavaScript berjalan di sisi pelayan dan menyokong permintaan serentak yang tinggi.

See all articles