ES8-새로운 기능

이 장에서는 ES8의 새로운 기능에 중점을 둡니다.

문자열 채우기

ES8은 문자열을 채우기위한 두 가지 문자열 처리 함수를 도입했습니다. 이러한 함수는 문자열 값의 시작과 끝에 공백 또는 원하는 문자 집합을 추가하는 데 사용할 수 있습니다.

끈. padStart ()

이 함수는 현재 문자열이 주어진 길이에 도달 할 때까지 시작부터 반복적으로 주어진 입력 문자열로 현재 문자열을 채 웁니다. padStart () 함수의 구문은 다음과 같습니다.

통사론

string_value.padStart(targetLength [, padString])

padStart () 함수는 다음과 같은 두 개의 매개 변수를받습니다.

  • targetLength− 패딩 후 문자열의 목표 길이를 나타내는 숫자 값. 이 매개 변수의 값이 기존 문자열 길이보다 작거나 같으면 문자열 값이있는 그대로 반환됩니다.

  • padString− 이것은 선택적 매개 변수입니다. 이 매개 변수는 문자열을 채우는 데 사용해야하는 문자를 지정합니다. 이 매개 변수에 값이 전달되지 않으면 문자열 값이 공백으로 채워집니다.

다음 예제는 문자열 변수 product_cost를 선언합니다. 문자열의 총 길이가 7이 될 때까지 변수는 왼쪽에서 0으로 채워집니다. 이 예제는 두 번째 매개 변수에 값이 전달되지 않은 경우 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를 선언합니다. 문자열의 총 길이가 7이 될 때까지 변수는 오른쪽에서 0으로 채워집니다. 이 예제는 두 번째 매개 변수에 값이 전달되지 않은 경우 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 루프를 사용하는 동안 배열의 후행 쉼표는 건너 뜁니다.

다음 예제는 foreach 루프를 사용하여 후행 쉼표로 배열을 반복합니다.

<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 ','
  • 후행 쉼표는 나머지 매개 변수와 함께 사용할 수 없습니다.

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

Object : entries () 및 values ​​()

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는 ES8에서 매우 중요한 기능으로 JavaScript의 Promises에 대한 구문 설탕입니다. await 키워드는 promise와 함께 사용됩니다. 이 키워드는 promise가 해결 될 때까지 함수 실행을 일시 중지하는 데 사용할 수 있습니다. await 키워드는 promise가 해결되면 promise의 값을 반환하고 promise가 거부되면 오류를 발생시킵니다. await 함수는 async로 표시된 함수 내에서만 사용할 수 있습니다. async 키워드를 사용하여 선언 된 함수는 항상 promise를 반환합니다.

통사론

await가있는 비동기 함수의 구문은 다음과 같습니다.

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

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

실행하는 데 2 ​​초가 걸리고 문자열 값을 반환하는 비동기 함수가있는 예를 고려하십시오. 이 함수는 아래와 같이 두 가지 방법으로 호출 할 수 있습니다.

  • promise.then () 사용
  • aync / await 사용.

아래 코드는 전통적인 ES6 구문 인 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>

위 코드의 출력은 다음과 같습니다.

end of script
response is:2 seconds have passed

아래 코드는 ES8 구문-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>

위 코드의 출력은 다음과 같습니다.

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

Async / await를 사용한 Promise Chaining

다음 예제는 async / await 구문을 사용하여 promise 체인을 구현합니다.

이 예에서는 add_positivenos_async()함수는 두 숫자를 비동기 적으로 추가하고 음수 값이 전달되면 거부합니다. 현재 비동기 함수 호출의 결과는 후속 함수 호출에 매개 변수로 전달됩니다.

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

위 코드의 출력은 다음과 같습니다.

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