ES9 - नई सुविधाएँ
यहां, हम ES9 में नई सुविधाओं के बारे में जानेंगे। आइए हम अतुल्यकालिक जनरेटर के बारे में समझकर शुरू करें।
अतुल्यकालिक जनरेटर और Iteration
अतुल्यकालिक जनरेटर का उपयोग करके अतुल्यकालिक जनरेटर बनाया जा सकता है asyncकीवर्ड। syntax एक async जनरेटर को परिभाषित करने के लिए नीचे दिया गया है -
async function* generator_name() {
//statements
}
उदाहरण
उदाहरण के बाद एक async जनरेटर दिखाता है जो प्रत्येक कॉल पर वादा करता है next() जनरेटर की विधि।
<script>
async function* load(){
yield await Promise.resolve(1);
yield await Promise.resolve(2);
yield await Promise.resolve(3);
}
let l = load();
l.next().then(r=>console.log(r))
l.next().then(r=>console.log(r))
l.next().then(r=>console.log(r))
l.next().then(r=>console.log(r))
</script>
उपरोक्त कोड का आउटपुट निम्नानुसार होगा -
{value: 1, done: false}
{value: 2, done: false}
{value: 3, done: false}
{value: undefined, done: true}
पाश का इंतजार
अतुल्यकालिक पुनरावृत्तियों को पारंपरिक का उपयोग करके पुनरावृत्त नहीं किया जा सकता है for..of loopसिंटैक्स वे वादे वापस करते हैं। ES9 परिचयfor await of loop समर्थन के लिए asynchronous iteration।
का उपयोग करने के लिए वाक्यविन्यास for await of loop नीचे दिया गया है, जहां,
प्रत्येक पुनरावृत्ति पर किसी भिन्न गुण का मान असाइन किया जाता है variable और एक वैरिएबल को कॉन्स्ट, लेट या वर् के साथ घोषित किया जा सकता है।
- iterable - ऐसी वस्तुएं जिनकी पुनरावृत्ति गुण से अधिक हो।
for await (variable of iterable) {
statement
}
उदाहरण
निम्न उदाहरण एक async जनरेटर को पुनरावृत्त करने के लिए लूप के इंतजार के उपयोग को दर्शाता है।
<script>
async function* load(){
yield await Promise.resolve(1);
yield await Promise.resolve(2);
yield await Promise.resolve(3);
}
async function test(){
for await (const val of load()){
console.log(val)
}
}
test();
console.log('end of script')
</script>
उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -
end of script
1
2
3
उदाहरण
निम्न उदाहरण लूप के इंतजार के लिए एक सरणी को पुनरावृत्त करता है।
<script>
async function fntest(){
for await (const val of [10,20,30,40]){
console.log(val)
}
}
fntest();
console.log('end of script')
</script>
उपरोक्त कोड का आउटपुट निम्नानुसार होगा -
end of script
10
20
30
40
बाकी / फैले हुए गुण
ES9 ऑब्जेक्ट्स के साथ रेस्ट एंड स्प्रेड ऑपरेटरों के उपयोग का समर्थन करता है।
उदाहरण: ऑब्जेक्ट और रेस्ट ऑपरेटर
निम्न उदाहरण एक वस्तु के साथ बाकी ऑपरेटर के उपयोग को दर्शाता है। छात्र की आयु संपत्ति के मूल्य को आयु चर में कॉपी किया जाता है, जबकि शेष गुणों के मूल्यों को बाकी वाक्यविन्यास `... 'का उपयोग करके दूसरे चर में कॉपी किया जाता है।
<script>
const student = {
age:10,
height:5,
weight:50
}
const {age,...other} = student;
console.log(age)
console.log(other)
</script>
उपरोक्त कोड का आउटपुट नीचे दिया गया है -
10
{height: 5, weight: 50}
उदाहरण: ऑब्जेक्ट और स्प्रेड ऑपरेटर
प्रसार ऑपरेटर का उपयोग कई ऑब्जेक्ट्स या क्लोनिंग ऑब्जेक्ट्स को संयोजित करने के लिए किया जा सकता है। यह निम्नलिखित उदाहरण में दिखाया गया है -
<script>
//spread operator
const obj1 = {a:10,b:20}
const obj2={c:30}
//clone obj1
const clone_obj={...obj1}
//combine obj1 and obj2
const obj3 = {...obj1,...obj2}
console.log(clone_obj)
console.log(obj3)
</script>
उपरोक्त कोड का आउटपुट निम्नानुसार होगा -
{a: 10, b: 20}
{a: 10, b: 20, c: 30}
वादा: अंत में ()
finally()जब भी किसी वाद का निपटारा किया जाता है, तो उसके परिणाम की परवाह किए बिना उसे क्रियान्वित किया जाता है। यह फ़ंक्शन एक वादा लौटाता है। यह दोनों वादे में कोड दोहराव से बचने के लिए इस्तेमाल किया जा सकता हैthen() तथा catch() संचालकों।
वाक्य - विन्यास
नीचे उल्लिखित वाक्य रचना फ़ंक्शन के लिए है finally()।
promise.finally(function() {
});
promise.finally(()=> {
});
उदाहरण
निम्न उदाहरण एक async फ़ंक्शन की घोषणा करता है जो 3 सेकंड की देरी के बाद एक सकारात्मक संख्या का वर्ग लौटाता है। यदि कोई ऋणात्मक संख्या पारित हो जाती है, तो फ़ंक्शन एक त्रुटि फेंकता है। अंत में ब्लॉक के बयानों को किसी भी मामले में निष्पादित किया जाता है, चाहे वह वादा खारिज कर दिया गया हो या हल किया गया हो।
<script>
let asyncSquareFn = function(n1){
return new Promise((resolve,reject)=>{
setTimeout(()=>{
if(n1>=0){
resolve(n1*n1)
}
else reject('NOT_POSITIVE_NO')
},3000)
})
}
console.log('Start')
asyncSquareFn(10)//modify to add -10
.then(result=>{
console.log("result is",result)
}).catch(error=>console.log(error))
.finally(() =>{
console.log("inside finally")
console.log("executes all the time")
})
console.log("End");
</script>
उपरोक्त कोड का आउटपुट नीचे दिखाया गया है
Start
End
//after 3 seconds
result is 100
inside finally
executes all the time
साँचा साक्षर संशोधन
ES7 के अनुसार, टैग किए गए टेम्पलेट निम्नलिखित एस्केप अनुक्रम के नियमों के अनुरूप हैं -
यूनिकोड एस्केप सीक्वेंस का उपयोग करके प्रतिनिधित्व किया जाता है "\u", उदाहरण के लिए \u2764\uFE0F
यूनिकोड कोड पॉइंट एस्केप सीक्वेंस का उपयोग करके प्रतिनिधित्व किया जाता है "\u{}", उदाहरण के लिए \u{2F}
हेक्साडेसिमल एस्केप सीक्वेंस का उपयोग करके प्रतिनिधित्व किया जाता है "\x", उदाहरण के लिए \xA8
ऑक्टल शाब्दिक एस्केप सीक्वेंस को "" का उपयोग करके दर्शाया गया है और उदाहरण के लिए एक या एक से अधिक अंक \125
ES2016 और पूर्व में, यदि अवैध एस्केप अनुक्रम टैग किए गए कार्यों के साथ उपयोग किए जाते हैं, तो एक सिंटैक्स त्रुटि को नीचे दिखाए गए के रूप में फेंक दिया जाएगा -
//tagged function with an invalid unicode sequence
myTagFn`\unicode1`
// SyntaxError: malformed Unicode character escape sequence
हालांकि, पहले के संस्करणों के विपरीत, ES9 अपरिभाषित के लिए अमान्य यूनिकोड अनुक्रम को पार्स करता है और एक त्रुटि नहीं फेंकता है। यह निम्नलिखित उदाहरण में दिखाया गया है -
<script>
function myTagFn(str) {
return { "parsed": str[0] }
}
let result1 =myTagFn`\unicode1` //invalid unicode character
console.log(result1)
let result2 =myTagFn`\u2764\uFE0F`//valid unicode
console.log(result2)
</script>
उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -
{parsed: undefined}
{parsed: "❤️"}
कच्चे तार
ES9 एक विशेष संपत्ति का परिचय देता है raw, टैग फ़ंक्शन के लिए पहले तर्क पर उपलब्ध है। यह संपत्ति आपको कच्चे तारों का उपयोग करने की अनुमति देती है, क्योंकि वे बच गए दृश्यों को संसाधित किए बिना दर्ज किए गए थे।
उदाहरण
<script>
function myTagFn(str) {
return { "Parsed": str[0], "Raw": str.raw[0] }
}
let result1 =myTagFn`\unicode`
console.log(result1)
let result2 =myTagFn`\u2764\uFE0F`
console.log(result2)
</script>
उपरोक्त कोड का आउटपुट निम्नानुसार होगा -
{Parsed: undefined, Raw: "\unicode"}
{Parsed: "❤️", Raw: "\u2764\uFE0F"}
नियमित अभिव्यक्ति की सुविधा
नियमित अभिव्यक्तियों में, डॉट ऑपरेटर या किसी एकल वर्ण से मेल खाने के लिए एक अवधि का उपयोग किया जाता है। . dot operator skips लाइन ब्रेक वर्णों की तरह \n, \r जैसा कि नीचे दिए गए उदाहरण में दिखाया गया है -
console.log(/Tutorials.Point/.test('Tutorials_Point')); //true
console.log(/Tutorials.Point/.test('Tutorials\nPoint')); //false
console.log(/Tutorials.Point/.test('Tutorials\rPoint')); //false
एक नियमित अभिव्यक्ति पैटर्न / regular_expression /.परीक्षण () विधि एक स्ट्रिंग पैरामीटर लेता है और रेगेक्स पैटर्न की खोज करता है। उपरोक्त उदाहरण में, एtest() methodट्यूटोरियल के साथ शुरू होने वाले पैटर्न की खोज, उसके बाद किसी भी एक चरित्र और प्वाइंट के साथ समाप्त। अगर हम उपयोग करते हैं\n या \r ट्यूटोरियल और बिंदु के बीच इनपुट स्ट्रिंग में परीक्षण () विधि झूठी वापस आ जाएगी।
true
false
false
ES9 एक नया झंडा पेश करता है - DotAllFlag (\s)जिसे रेगेक्स के साथ लाइन टर्मिनेटर और इमोजीस के साथ प्रयोग किया जा सकता है। यह निम्नलिखित उदाहरण में दिखाया गया है -
console.log(/Tutorials.Point/s.test('Tutorials\nPoint'));
console.log(/Tutorials.Point/s.test('Tutorials\rPoint'));
उपरोक्त कोड का आउटपुट निम्नानुसार होगा -
true
true
जिसका नाम कैप्चर ग्रुप रखा गया
ES9 से पहले, कैप्चर ग्रुप्स को इंडेक्स द्वारा एक्सेस किया गया था। ES9 हमें समूहों को पकड़ने के लिए नाम निर्दिष्ट करने की अनुमति देता है। उसी का सिंटैक्स नीचे दिया गया है -
(?<Name1>pattern1)
उदाहरण
const birthDatePattern = /(?<myYear>[0-9]{4})-(?<myMonth>[0-9]{2})/;
const birthDate = birthDatePattern.exec('1999-04');
console.log(birthDate.groups.myYear);
console.log(birthDate.groups.myMonth);
उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -
1999
04