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