ES8 - คุณสมบัติใหม่

บทนี้มุ่งเน้นไปที่คุณสมบัติใหม่ใน ES8

การเว้นสตริง

ES8 แนะนำฟังก์ชันการจัดการสตริงสองแบบสำหรับการขยายสตริง ฟังก์ชันเหล่านี้สามารถใช้เพื่อเพิ่มช่องว่างหรือชุดอักขระที่ต้องการในจุดเริ่มต้นและจุดสิ้นสุดของค่าสตริง

สตริง padStart ()

ฟังก์ชันนี้จะเสริมสตริงปัจจุบันด้วยสตริงอินพุตที่กำหนดซ้ำ ๆ ตั้งแต่เริ่มต้นจนกระทั่งสตริงปัจจุบันถึงความยาวที่กำหนด ไวยากรณ์ของฟังก์ชัน padStart () ได้รับด้านล่าง -

ไวยากรณ์

string_value.padStart(targetLength [, padString])

ฟังก์ชั่น padStart () ยอมรับพารามิเตอร์สองตัวซึ่งมีดังนี้ -

  • targetLength- ค่าตัวเลขที่แสดงถึงความยาวเป้าหมายของสตริงหลังจากช่องว่างภายใน หากค่าของพารามิเตอร์นี้น้อยกว่าหรือเท่ากับความยาวที่มีอยู่ของสตริงค่าสตริงจะถูกส่งกลับตามที่เป็นอยู่

  • padString- นี่คือพารามิเตอร์ทางเลือก พารามิเตอร์นี้ระบุอักขระที่ควรใช้เพื่อเติมสตริง ค่าสตริงจะถูกเติมช่องว่างหากไม่มีการส่งผ่านค่าไปยังพารามิเตอร์นี้

ตัวอย่าง

ตัวอย่างต่อไปนี้ประกาศตัวแปรสตริง product_cost ตัวแปรจะถูกเติมด้วยเลขศูนย์จากด้านซ้ายจนกระทั่งความยาวทั้งหมดของสตริงเท่ากับเจ็ด ตัวอย่างยังแสดงลักษณะการทำงานของฟังก์ชัน padStart () หากไม่มีการส่งผ่านค่าไปยังพารามิเตอร์ที่สอง

<script>

   //pad the String with 0
   let product_cost = '1699'.padStart(7,0)
   console.log(product_cost)
   console.log(product_cost.length)

   //pad the String with blank spaces
   let product_cost1 = '1699'.padStart(7)
   console.log(product_cost1)
   console.log(product_cost1.length)
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นไปตามที่ระบุไว้ด้านล่าง -

0001699
7
1699
7

String.padEnd ()

ฟังก์ชันนี้จะเสริมสตริงปัจจุบันด้วยสตริงอินพุตที่กำหนดซ้ำ ๆ จากจุดสิ้นสุดจนกระทั่งสตริงปัจจุบันถึงความยาวที่กำหนด

ไวยากรณ์ของฟังก์ชัน padEnd () ได้รับด้านล่าง -

ไวยากรณ์

string_value.padEnd(targetLength [, padString])

ฟังก์ชัน padEnd () ยอมรับสองพารามิเตอร์ -

  • targetLength- ค่าตัวเลขที่แสดงถึงความยาวเป้าหมายของสตริงหลังจากช่องว่างภายใน หากค่าของพารามิเตอร์นี้น้อยกว่าหรือเท่ากับความยาวที่มีอยู่ของสตริงค่าสตริงจะถูกส่งกลับตามที่เป็นอยู่

  • padString- นี่คือพารามิเตอร์ทางเลือก พารามิเตอร์นี้ระบุอักขระที่ควรใช้เพื่อเติมสตริง ค่าสตริงจะถูกเติมช่องว่างหากไม่มีการส่งผ่านค่าไปยังพารามิเตอร์นี้

ตัวอย่าง

ตัวอย่างต่อไปนี้ประกาศตัวแปรสตริง product_cost ตัวแปรจะถูกเติมด้วยศูนย์จากด้านขวาจนกระทั่งความยาวทั้งหมดของสตริงเท่ากับเจ็ด ตัวอย่างยังแสดงลักษณะการทำงานของฟังก์ชัน padStart () หากไม่มีการส่งผ่านค่าไปยังพารามิเตอร์ที่สอง

<script>

   //pad the string with x
   let product_cost = '1699'.padEnd(7,'x')
   console.log(product_cost)
   console.log(product_cost.length)
   
   //pad the string with spaces
   let product_cost1 = '1699'.padEnd(7)
   console.log(product_cost1)
   console.log(product_cost1.length)
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นดังที่ระบุไว้ด้านล่าง -

1699xxx
7
1699
7

เครื่องหมายจุลภาคต่อท้าย

เครื่องหมายจุลภาคต่อท้ายเป็นเพียงลูกน้ำหลังรายการสุดท้ายในรายการ เครื่องหมายจุลภาคต่อท้ายเรียกอีกอย่างว่าเครื่องหมายจุลภาคสุดท้าย

เครื่องหมายจุลภาคและอาร์เรย์ต่อท้าย

เครื่องหมายจุลภาคต่อท้ายในอาร์เรย์จะถูกข้ามไปในขณะที่ใช้ Array.prototype.forEach loop

ตัวอย่าง

ตัวอย่างต่อไปนี้การวนซ้ำอาร์เรย์โดยใช้เครื่องหมายจุลภาคต่อท้ายโดยใช้ foreach loop

<script>

   let marks = [100,90,80,,]
   console.log(marks.length)
   console.log(marks)
   marks.forEach(function(e){ //ignores empty value in array
      console.log(e)
   })
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นดังที่แสดงด้านล่าง -

4
[100, 90, 80, empty]
100
90
80

จุลภาคต่อท้ายและการเรียกฟังก์ชัน

เครื่องหมายจุลภาคต่อท้ายส่งผ่านเป็นอาร์กิวเมนต์เมื่อกำหนดหรือเรียกใช้ฟังก์ชันจะถูกละเว้นโดยเอ็นจินรันไทม์ JavaScript อย่างไรก็ตามมีสองข้อยกเว้น -

  • คำจำกัดความของฟังก์ชันหรือการเรียกใช้ที่มีเพียงลูกน้ำจะส่งผลให้เกิด SyntaxError ตัวอย่างเช่นข้อมูลโค้ดต่อไปนี้จะทำให้เกิดข้อผิดพลาด -

function test(,){} // SyntaxError: missing formal parameter
(,)=>{}; //SyntaxError: expected expression, got ','
test(,) //SyntaxError: expected expression, got ','
  • ไม่สามารถใช้เครื่องหมายจุลภาคต่อท้ายกับพารามิเตอร์ rest

function test(...arg1,){} // SyntaxError: parameter after rest parameter
(...arg1,)=>{} // SyntaxError: expected closing parenthesis, got ','

ตัวอย่าง

ตัวอย่างต่อไปนี้ประกาศฟังก์ชันที่มีเครื่องหมายจุลภาคต่อท้ายในรายการอาร์กิวเมนต์

<script>

   function sumOfMarks(marks,){ // trailing commas are ignored
      let sum=0;
      marks.forEach(function(e){
         sum+=e;
      })
      return sum;
   }

   console.log(sumOfMarks([10,20,30]))
   console.log(sumOfMarks([1,2,3],))// trailing comma is ignored
</script>

ผลลัพธ์ของรหัสด้านบนมีดังนี้ -

60
6

วัตถุ: รายการ () และค่า ()

ES8 แนะนำวิธีการใหม่ต่อไปนี้สำหรับประเภทวัตถุในตัว -

  • Object.entries - เมธอด Object.entries () สามารถใช้เพื่อเข้าถึงคุณสมบัติทั้งหมดของอ็อบเจกต์

  • Object.values() - วิธี Object.values ​​() สามารถใช้เพื่อเข้าถึงค่าของคุณสมบัติทั้งหมดของวัตถุ

  • Object.getOwnPropertyDescriptors()- วิธีนี้จะส่งคืนอ็อบเจกต์ที่มีตัวบอกคุณสมบัติของอ็อบเจ็กต์เองทั้งหมด วัตถุว่างอาจถูกส่งคืนหากวัตถุไม่มีคุณสมบัติใด ๆ

ตัวอย่าง

<script>
   const student ={
      firstName:'Kannan',
      lastName:'Sudhakaran'
   }
   console.log(Object.entries(student))
   console.log(Object.values(student))
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นดังนี้ -

[
["firstName", "Kannan"],
["lastName", "Sudhakaran"],
]
["Kannan", "Sudhakaran"]

ตัวอย่าง

<script>
   const marks = [10,20,30,40]
   console.log(Object.entries(marks))
   console.log(Object.values(marks))
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นไปตามที่ระบุด้านล่าง -

["0", 10],
["1", 20],
["2", 30],
["3", 40]
]
[10, 20, 30, 40]

ตัวอย่าง

<script>
   const student = {
      firstName : 'Mohtashim',
      lastName: 'Mohammad',
      get fullName(){
         return this.firstName + ':'+ this.lastName
      }
   }
   console.log(Object.getOwnPropertyDescriptors(student))
</script>

ผลลัพธ์ของโค้ดด้านบนจะเป็นดังที่ระบุไว้ด้านล่าง -

{firstName: {value: "Mohtashim", writable: true, enumerable: true, configurable: true}
fullName: {get: ƒ, set: undefined, enumerable: true, configurable: true}
lastName: {value: "Mohammad", writable: true, enumerable: true, configurable: true}
}

Async และ Await

Async/Await is a very important feature in ES8.It is a syntactic sugar for Promises in JavaScript. The await keyword is used with promises. This keyword can be used to pause the execution of a function till a promise is settled. The await keyword returns value of the promise if the promise is resolved while it throws an error if the promise is rejected. The await function can only be used inside functions marked as async. A function that is declared using the async keyword always returns a promise.

Syntax

The syntax of async function with await is given below −

async function function_name(){
   let result_of_functionCall = await longRunningMethod();
}
//invoking async function

function_name().then(()=>{})
   .catch(()=>{})

Consider an example that has an asynchronous function that takes two seconds to execute and returns a string value. The function can be invoked in two ways as shown below

  • Using promise.then()
  • Using aync/await.

The below code shows invoking the asynchronous function using the traditional ES6 syntax - promise.then()

<script>
   function fnTimeConsumingWork(){
      return new Promise((resolve,reject)=>{
         setTimeout(() => {
            resolve('response is:2 seconds have passed')
         }, 2000);
      })
   }

   fnTimeConsumingWork().then(resp=>{
      console.log(resp)
   })
   console.log('end of script')
</script>

The output of the above code will be as follows −

end of script
response is:2 seconds have passed

The below code shows a cleaner way of invoking the asynchronous function using ES8 syntax - async/await

<script>
   function fnTimeConsumingWork(){
      return new Promise((resolve,reject)=>{
         setTimeout(() => {
            resolve('response is:2 seconds have passed')
         }, 2000);
      })
   }
   async function my_AsyncFunc(){
      console.log('inside my_AsyncFunc')
      const response = await fnTimeConsumingWork();// clean and readable
      console.log(response)
   }
   my_AsyncFunc();
   console.log("end of script")
</script>

The output of the above code will be as mentioned below −

inside my_AsyncFunc
end of script
response is:2 seconds have passed

Promise chaining with Async/await

The following example implements promise chaining using the async/await syntax.

In this example, add_positivenos_async() function adds two numbers asynchronously and rejects if negative values are passed. The result from the current asynchronous function call is passed as parameter to the subsequent function calls.

<script>
   function add_positivenos_async(n1, n2) {
      let p = new Promise(function (resolve, reject) {
         if (n1 >= 0 && n2 >= 0) {
            //do some complex time consuming work
            resolve(n1 + n2)
         } else
            reject('NOT_Postive_Number_Passed')
      })
      return p;
   }
   async function addInSequence() {
      let r1 = await add_positivenos_async(10, 20)
      console.log("first result", r1);
      let r2 = await add_positivenos_async(r1, r1);
      console.log("second result", r2)
      let r3 = await add_positivenos_async(r2, r2);
      console.log("third result", r3)
      return "Done Sequence"
   }
   addInSequence().then((r)=>console.log("Async :",r));
   console.log('end')
</script>

The output of the above code will be as given below−

end
first result 30
second result 60
third result 120
Async : Done Sequence