ES6 - ไวยากรณ์
Syntaxกำหนดชุดของกฎสำหรับการเขียนโปรแกรม ข้อกำหนดทุกภาษากำหนดไวยากรณ์ของตัวเอง
โปรแกรม JavaScript สามารถประกอบด้วย -
Variables - แสดงถึงบล็อกหน่วยความจำที่มีชื่อซึ่งสามารถจัดเก็บค่าสำหรับโปรแกรมได้
Literals - แสดงถึงค่าคงที่ / คงที่
Operators - สัญลักษณ์ที่กำหนดวิธีการประมวลผลตัวถูกดำเนินการ
Keywords - คำที่มีความหมายพิเศษในบริบทของภาษา
ตารางต่อไปนี้แสดงรายการคำหลักบางคำใน JavaScript คำหลักที่ใช้บ่อยบางคำแสดงอยู่ในตารางต่อไปนี้
หยุดพัก | เช่น | ใด ๆ | สวิตซ์ |
กรณี | ถ้า | โยน | อื่น |
หลากหลาย | จำนวน | สตริง | รับ |
โมดูล | ชนิด | อินสแตนซ์ของ | ประเภทของ |
ในที่สุด | สำหรับ | enum | ส่งออก |
ในขณะที่ | เป็นโมฆะ | นี้ | ใหม่ |
โมฆะ | สุดยอด | จับ | ปล่อย |
คงที่ | กลับ | จริง | เท็จ |
Modules - แสดงถึงบล็อกรหัสที่สามารถนำมาใช้ซ้ำในโปรแกรม / สคริปต์ต่างๆ
Comments- ใช้เพื่อปรับปรุงการอ่านโค้ด สิ่งเหล่านี้ถูกละเว้นโดยเอ็นจิ้น JavaScript
Identifiers - นี่คือชื่อที่กำหนดให้กับองค์ประกอบในโปรแกรมเช่นตัวแปรฟังก์ชัน ฯลฯ กฎสำหรับตัวระบุคือ -
ตัวระบุอาจมีทั้งอักขระและตัวเลข อย่างไรก็ตามตัวระบุไม่สามารถขึ้นต้นด้วยตัวเลข
ตัวระบุไม่สามารถใส่สัญลักษณ์พิเศษยกเว้นขีดล่าง (_) หรือเครื่องหมายดอลลาร์ ($)
ตัวระบุไม่สามารถเป็นคำหลัก พวกเขาต้องมีเอกลักษณ์
ตัวระบุมีความละเอียดอ่อน ตัวระบุต้องไม่มีช่องว่าง
ตารางต่อไปนี้แสดงตัวระบุที่ถูกต้องและไม่ถูกต้อง
ตัวอย่างตัวระบุที่ถูกต้อง | ตัวอย่างของตัวระบุที่ไม่ถูกต้อง |
---|---|
ชื่อจริง ชื่อจริง num1 ผลลัพธ์ $ |
Var # ชื่อจริง ชื่อจริง 1 หมายเลข |
ช่องว่างและเส้นแบ่ง
ES6 ละเว้นช่องว่างแท็บและบรรทัดใหม่ที่ปรากฏในโปรแกรม คุณสามารถใช้ช่องว่างแท็บและบรรทัดใหม่ได้อย่างอิสระในโปรแกรมของคุณและคุณมีอิสระในการจัดรูปแบบและเยื้องโปรแกรมของคุณอย่างเป็นระเบียบและสม่ำเสมอซึ่งทำให้โค้ดอ่านและเข้าใจได้ง่าย
JavaScript คำนึงถึงขนาดตัวพิมพ์
JavaScript คำนึงถึงขนาดตัวพิมพ์ ซึ่งหมายความว่า JavaScript แยกความแตกต่างระหว่างอักขระตัวพิมพ์ใหญ่และตัวพิมพ์เล็ก
อัฒภาคเป็นทางเลือก
คำสั่งแต่ละบรรทัดเรียกว่า a statement. อัฒภาคเป็นทางเลือกใน JavaScript
ตัวอย่าง
console.log("hello world")
console.log("We are learning ES6")
บรรทัดเดียวสามารถมีหลายคำสั่ง อย่างไรก็ตามข้อความเหล่านี้ต้องคั่นด้วยอัฒภาค
ความคิดเห็นใน JavaScript
Commentsเป็นวิธีปรับปรุงความสามารถในการอ่านของโปรแกรม ข้อคิดเห็นสามารถใช้เพื่อรวมข้อมูลเพิ่มเติมเกี่ยวกับโปรแกรมเช่นผู้เขียนโค้ดคำแนะนำเกี่ยวกับฟังก์ชัน / โครงสร้าง ฯลฯ คอมไพเลอร์ไม่สนใจข้อคิดเห็น
JavaScript รองรับความคิดเห็นประเภทต่อไปนี้ -
Single-line comments (//) - ข้อความใด ๆ ระหว่าง a // และท้ายบรรทัดจะถือว่าเป็นความคิดเห็น
Multi-line comments (/* */) - ความคิดเห็นเหล่านี้อาจครอบคลุมหลายบรรทัด
ตัวอย่าง
//this is single line comment
/* This is a
Multi-line comment
*/
รหัส JavaScript แรกของคุณ
เริ่มจากตัวอย่าง“ Hello World” แบบดั้งเดิม
var message = "Hello World"
console.log(message)
โปรแกรมสามารถวิเคราะห์เป็น -
บรรทัดที่ 1 ประกาศตัวแปรด้วยข้อความชื่อ ตัวแปรเป็นกลไกในการจัดเก็บค่าในโปรแกรม
บรรทัดที่ 2 พิมพ์ค่าของตัวแปรไปยังพร้อมต์ ในที่นี้คอนโซลหมายถึงหน้าต่างเทอร์มินัล บันทึกฟังก์ชัน () ใช้เพื่อแสดงข้อความบนหน้าจอ
ดำเนินการตามรหัส
เราจะใช้ Node.js เพื่อรันโค้ดของเรา
Step 1 - บันทึกไฟล์เป็น Test.js
Step 2 - คลิกขวาที่ไฟล์ Test.js ภายใต้ตัวเลือกไฟล์ที่ใช้งานได้ในหน้าต่าง project-explorer ของ Visual Studio Code
Step 3 - เลือกเปิดในตัวเลือกพร้อมรับคำสั่ง
Step 4 - พิมพ์คำสั่งต่อไปนี้ในหน้าต่างเทอร์มินัลของโหนด
node Test.js
เอาต์พุตต่อไปนี้จะแสดงเมื่อการเรียกใช้ไฟล์สำเร็จ
Hello World
Node.js และ JS / ES6
คุณลักษณะของ ECMAScript 2015 (ES6) แบ่งออกเป็นสามกลุ่ม -
For Shipping - นี่คือคุณสมบัติที่ V8 พิจารณาว่าเสถียร
Staged Features - คุณสมบัติเหล่านี้เกือบจะเสร็จสมบูรณ์ แต่ทีม V8 ไม่ถือว่าเสถียร
In Progress - คุณสมบัติเหล่านี้ควรใช้เพื่อการทดสอบเท่านั้น
คุณลักษณะประเภทแรกได้รับการสนับสนุนอย่างสมบูรณ์และเปิดใช้งานโดยค่าเริ่มต้นโดยโหนด ฟีเจอร์แบบสเตจต้องใช้แฟล็กรันไทม์ - - ฮาร์มอลเพื่อดำเนินการ
รายการแฟล็ก CLI เฉพาะของคอมโพเนนต์สำหรับ Node.js สามารถพบได้ที่นี่ -
โหมดเข้มงวด
ข้อกำหนด ECMAScript รุ่นที่ห้าเปิดตัวโหมดเข้มงวด โหมดเข้มงวดกำหนดชั้นของข้อ จำกัด บน JavaScript มีการเปลี่ยนแปลงหลายอย่างกับความหมายของ JavaScript ปกติ
รหัสสามารถเปลี่ยนให้ทำงานในโหมดเข้มงวดได้โดยรวมสิ่งต่อไปนี้ -
// Whole-script strict mode syntax
"use strict";
v = "Hi! I'm a strict mode script!"; // ERROR: Variable v is not declared
ในตัวอย่างข้างต้นโค้ดทั้งหมดจะทำงานเป็นตัวแปรที่ จำกัด ของ JavaScript
JavaScript ยังอนุญาตให้ จำกัด โหมดเข้มงวดภายในขอบเขตของบล็อกเหมือนกับฟังก์ชัน มีภาพประกอบดังนี้ -
v = 15
function f1() {
"use strict";
var v = "Hi! I'm a strict mode script!";
}
ในตัวอย่างข้างต้นโค้ดใด ๆ ที่อยู่นอกฟังก์ชันจะทำงานในโหมดที่ไม่เข้มงวด คำสั่งทั้งหมดภายในฟังก์ชันจะดำเนินการในโหมดเข้มงวด
ES6 และรอก
โดยค่าเริ่มต้นเอ็นจิ้น JavaScript จะย้ายการประกาศไปที่ด้านบน คุณลักษณะนี้เรียกว่าhoisting. คุณลักษณะนี้ใช้กับตัวแปรและฟังก์ชัน Hoisting อนุญาตให้ JavaScript ใช้ส่วนประกอบก่อนที่จะมีการประกาศ อย่างไรก็ตามแนวคิดของการชักรอกใช้ไม่ได้กับสคริปต์ที่ทำงานในโหมดเข้มงวด
การชักรอกแบบแปรผันและการยกฟังก์ชันอธิบายไว้ในบทต่อ ๆ ไป