ईएस 6 - त्वरित गाइड

ECMAScript (ES) ECMAScript इंटरनेशनल द्वारा मानकीकृत एक स्क्रिप्टिंग भाषा विनिर्देश है। इसका उपयोग क्लाइंट-साइड स्क्रिप्टिंग को सक्षम करने के लिए अनुप्रयोगों द्वारा किया जाता है। विनिर्देशन स्वयं, पर्ल, पायथन, जावा आदि प्रोग्रामिंग भाषाओं से प्रभावित होता है। जावास्क्रिप्ट, जावास्क्रिप्ट और एक्शनस्क्रिप्ट जैसी भाषाएँ इस विनिर्देश द्वारा शासित होती हैं।

यह ट्यूटोरियल आपको जावास्क्रिप्ट में ES6 कार्यान्वयन के लिए पेश करता है।

जावास्क्रिप्ट

जावास्क्रिप्ट को 1995 में नेटस्केप कम्युनिकेशंस कॉरपोरेशन में एक डेवलपर ब्रेंडन ईच द्वारा विकसित किया गया था। जावास्क्रिप्ट ने मोचा नाम के साथ जीवन शुरू किया था, और आधिकारिक तौर पर जावास्क्रिप्ट में नाम बदलने से पहले लाइवस्क्रिप्ट का नाम दिया गया था। यह एक स्क्रिप्टिंग भाषा है जिसे ब्राउज़र द्वारा निष्पादित किया जाता है, अर्थात क्लाइंट के अंत में। यह उत्तरदायी वेबपृष्ठों को विकसित करने के लिए HTML के साथ संयोजन में उपयोग किया जाता है।

ECMA Script6 के कार्यान्वयन की चर्चा यहाँ निम्नलिखित नई विशेषताओं को शामिल करती है -

  • स्थिरांक के लिए समर्थन
  • स्कोप को ब्लॉक करें
  • एरो फ़ंक्शंस
  • विस्तारित पैरामीटर हैंडलिंग
  • साँचा साहित्य
  • विस्तारित साहित्य
  • संवर्धित वस्तु गुण
  • डी-स्ट्रक्चरिंग असाइनमेंट
  • Modules
  • Classes
  • Iterators
  • Generators
  • Collections
  • विभिन्न वर्गों के लिए नए तरीकों में निर्मित
  • Promises

ECMAScript संस्करण

ECMA-262 के नौ संस्करण हैं जो इस प्रकार हैं -

संस्करण नाम विवरण
1 ECMAScript 1 पहला संस्करण 1997 में जारी किया गया
2 ECMAScript 2 1998 में जारी दूसरा संस्करण, आईएसओ / आईईसी 16262 मानक को पूरा करने के लिए मामूली बदलाव
3 ECMAScript 3 तृतीय संस्करण भाषा संवर्द्धन के साथ 1999 में जारी किया गया
4 ECMAScript 4 चौथा संस्करण रिलीज योजना को गिरा दिया गया था, कुछ सुविधाओं को बाद में ईएस 6 और अन्य जटिल सुविधाओं में जोड़ा गया
5 ECMAScript 5 पांचवां संस्करण 2009 में जारी किया गया
5.1 ECMAScript 5.1 5.1 संस्करण 2011 में जारी किया गया, आईएसओ / आईईसी 16262: 2011 मानक को पूरा करने के लिए मामूली बदलाव
6 ईसीएमएस्क्रिप्ट 2015 / ईएस 6 2015 में जारी छठा संस्करण, नई सुविधाओं के लिए ईएस 6 अध्याय देखें
7 ECMAScript 2016 / ES7 2016 में जारी सातवां संस्करण, नई सुविधाओं के लिए ईएस 7 अध्याय देखें
8 ECMAScript 2017 / ES8 2017 में आठ संस्करण जारी किए गए, नई सुविधाओं के लिए ईएस 8 अध्याय देखें
9 ECMAScript 2018 / ES9 2018 में जारी नौवां संस्करण, नई सुविधाओं के लिए ईएस 9 अध्याय देखें

इस अध्याय में, हम ES6 के लिए पर्यावरण की स्थापना पर चर्चा करेंगे।

स्थानीय पर्यावरण सेटअप

जावास्क्रिप्ट किसी भी ब्राउज़र, किसी भी होस्ट और किसी भी OS पर चल सकता है। आपको जावास्क्रिप्ट प्रोग्राम मानक लिखने और परीक्षण करने के लिए निम्नलिखित की आवश्यकता होगी -

पाठ संपादक

पाठ संपादक आपको अपना स्रोत कोड लिखने में मदद करता है। कुछ संपादकों के उदाहरणों में विंडोज नोटपैड, नोटपैड ++, एमएसीएस, वीआईएम या vi आदि शामिल हैं। संपादकों का इस्तेमाल ऑपरेटिंग सिस्टम के साथ भिन्न हो सकता है। स्रोत फ़ाइलों को आम तौर पर के साथ नामित किया जाता हैextension.js

Node.js स्थापित करना

Node.jsसर्वर-साइड जावास्क्रिप्ट के लिए एक खुला स्रोत, क्रॉस-प्लेटफॉर्म रनटाइम वातावरण है। एक ब्राउज़र समर्थन के बिना जावास्क्रिप्ट चलाने के लिए Node.js की आवश्यकता होती है। यह कोड को निष्पादित करने के लिए Google V8 जावास्क्रिप्ट इंजन का उपयोग करता है। आप अपने मंच के लिए Node.js स्रोत कोड या पूर्व-निर्मित इंस्टॉलर डाउनलोड कर सकते हैं। नोड पर उपलब्ध हैhttps://nodejs.org/en/download

विंडोज पर स्थापना

डाउनलोड करें और चलाएं .msi installer नोड के लिए

यह सत्यापित करने के लिए कि क्या इंस्टॉलेशन सफल था, कमांड दर्ज करें node –v टर्मिनल विंडो में।

मैक ओएस एक्स पर स्थापना

ओएस एक्स पर नोड.जेएस स्थापित करने के लिए आप एक पूर्व संकलित बाइनरी पैकेज डाउनलोड कर सकते हैं जो एक अच्छा और आसान इंस्टॉलेशन बनाता है। Www.nodejs.org पर जाएं और नवीनतम पैकेज डाउनलोड करने के लिए इंस्टॉल बटन पर क्लिक करें।

से पैकेज स्थापित करें .dmg स्थापित विज़ार्ड के साथ अनुसरण करके जो दोनों को स्थापित करेगा node तथा npm। npm नोड पैकेज प्रबंधक है जो Node.js. के लिए अतिरिक्त पैकेजों को स्थापित करने की सुविधा देता है

लिनक्स पर स्थापना

आपको कई नंबर इंस्टॉल करने होंगे dependencies इससे पहले कि आप Node.js और npm को स्थापित कर सकें।

  • Ruby तथा GCC। आपको रूबी 1.8.6 या नए और जीसीसी 4.2 या नए की आवश्यकता होगी

  • Homebrew.Homebrew मूल रूप से Mac के लिए एक पैकेज मैनेजर है, लेकिन इसे Linux को Linuxbrew के रूप में पोर्ट किया गया है। आप Homebrew के बारे में अधिक जान सकते हैंhttp://brew.sh/ पर http://brew.sh/linuxbrew।

एकीकृत विकास पर्यावरण (IDE) समर्थन

जावास्क्रिप्ट को विजुअल स्टूडियो, सबलाइम टेक्स्ट 2, वेबस्टॉर्म / PHPStorm, ग्रहण, ब्रैकेट्स आदि जैसे विकास के वातावरण के ढेर पर बनाया जा सकता है। विज़ुअल स्टूडियो कोड और ब्रैकेट्स IDE की चर्चा इस खंड में की गई है। यहां उपयोग किया जाने वाला विकास वातावरण विजुअल स्टूडियो कोड (विंडोज प्लेटफॉर्म) है।

विजुअल स्टूडियो कोड

यह विजुअल स्टूडियो से ओपन सोर्स आईडीई है। यह मैक ओएस एक्स, लिनक्स और विंडोज प्लेटफार्मों के लिए उपलब्ध है। VScode पर उपलब्ध हैhttps://code.visualstudio.com।

विंडोज पर स्थापना

विंडोज के लिए विजुअल स्टूडियो कोड डाउनलोड करें।

सेटअप प्रक्रिया शुरू करने के लिए VSCodeSetup.exe पर डबल-क्लिक करें । इसमें केवल एक मिनट लगेगा।

निम्नलिखित IDE का स्क्रीनशॉट है।

आप फ़ाइल के पथ पर सीधे फ़ाइल पर राइट-क्लिक कर सकते हैं → कमांड प्रॉम्प्ट में खोलें। इसी तरह,Reveal in Explorer विकल्प फ़ाइल एक्सप्लोरर में फ़ाइल दिखाता है।

मैक ओएस एक्स पर स्थापना

विजुअल स्टूडियो कोड का मैक ओएस एक्स विशिष्ट इंस्टॉलेशन गाइड पर पाया जा सकता है https://code.visualstudio.com/docs/setup/setup-overview

लिनक्स पर स्थापना

विज़ुअल स्टूडियो कोड के लिए लिनक्स विशिष्ट इंस्टॉलेशन गाइड पर पाया जा सकता है https://code.visualstudio.com/Docs/editor/setup.

कोष्ठक

ब्रैकेट वेब डेवलपमेंट के लिए एक फ्री ओपन-सोर्स एडिटर है, जिसे एडोब सिस्टम्स द्वारा बनाया गया है। यह लिनक्स, विंडोज और मैक ओएस एक्स के लिए उपलब्ध है। ब्रैकेट में उपलब्ध हैhttp://brackets.io।

आप एक और एक्सटेंशन ब्रैकेट शेल जोड़कर ब्रैकेट के भीतर DOS प्रॉम्प्ट / शेल चला सकते हैं।

स्थापना के बाद, आपको संपादक के दाईं ओर शेल का एक आइकन मिलेगा

। एक बार जब आप आइकन पर क्लिक करते हैं, तो आपको शेल विंडो दिखाई देगी जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

तुम पूरी तरह तैयार हो!!!

Syntaxप्रोग्राम लिखने के लिए नियमों के सेट को परिभाषित करता है। हर भाषा विनिर्देश अपने स्वयं के वाक्यविन्यास को परिभाषित करता है।

एक जावास्क्रिप्ट प्रोग्राम से बना जा सकता है -

  • Variables - एक नामित मेमोरी ब्लॉक का प्रतिनिधित्व करता है जो कार्यक्रम के लिए मूल्यों को संग्रहीत कर सकता है।

  • Literals - निरंतर / निश्चित मूल्यों का प्रतिनिधित्व करता है।

  • Operators - प्रतीक जो परिभाषित करते हैं कि ऑपरेंड कैसे संसाधित होंगे।

  • Keywords - ऐसे शब्द जिनका किसी भाषा के संदर्भ में विशेष अर्थ होता है।

निम्न तालिका जावास्क्रिप्ट में कुछ खोजशब्दों को सूचीबद्ध करती है। आमतौर पर उपयोग किए जाने वाले कुछ कीवर्ड निम्न तालिका में सूचीबद्ध हैं।

टूटना जैसा कोई भी स्विच
मामला अगर फेंकना अन्य
वर संख्या तार प्राप्त
मापांक प्रकार का उदाहरण प्रकार का
आखिरकार के लिये enum निर्यात
जबकि शून्य यह नया
शून्य उत्तम पकड़ लश्कर
स्थिर वापसी सच असत्य
  • Modules - कोड ब्लॉक का प्रतिनिधित्व करता है जिसे विभिन्न कार्यक्रमों / लिपियों में पुन: उपयोग किया जा सकता है।

  • Comments- कोड पठनीयता में सुधार करने के लिए उपयोग किया जाता है। इन्हें जावास्क्रिप्ट इंजन द्वारा नजरअंदाज किया जाता है।

  • Identifiers - ये प्रोग्राम में तत्वों को दिए गए नाम हैं जैसे कि चर, फ़ंक्शन, आदि। पहचानकर्ताओं के लिए नियम हैं -

    • पहचानकर्ताओं में वर्ण और अंक दोनों शामिल हो सकते हैं। हालाँकि, पहचानकर्ता एक अंक से शुरू नहीं हो सकता है।

    • पहचानकर्ता अंडरस्कोर (_) या एक डॉलर चिह्न ($) को छोड़कर विशेष प्रतीकों को शामिल नहीं कर सकते।

    • पहचानकर्ता कीवर्ड नहीं हो सकते। वे अद्वितीय होना चाहिए।

    • पहचानकर्ता मामले संवेदनशील होते हैं। पहचानकर्ताओं में स्थान नहीं हो सकते।

निम्न तालिका कुछ मान्य और अमान्य पहचानकर्ताओं को दर्शाती है।

मान्य पहचानकर्ताओं के उदाहरण अमान्य पहचानकर्ताओं के उदाहरण

पहला नाम

पहला नाम

संख्या 1

$ परिणाम

वार #

पहला नाम

पहला नाम

1NUMBER

व्हॉट्सएप और लाइन ब्रेक

ES6 कार्यक्रमों में दिखाई देने वाले रिक्त स्थान, टैब और नए सिरे को अनदेखा करता है। आप अपने प्रोग्राम में स्पेस, टैब और न्यूलाइन्स का खुलकर इस्तेमाल कर सकते हैं और आप अपने प्रोग्राम्स को साफ-सुथरे और सुसंगत तरीके से फॉर्मेट और इंडेंट करने के लिए स्वतंत्र हैं जिससे कोड को पढ़ना और समझना आसान हो जाता है।

जावास्क्रिप्ट केस-संवेदी है

जावास्क्रिप्ट केस-संवेदी है। इसका मतलब है कि जावास्क्रिप्ट अपरकेस और लोअरकेस वर्णों के बीच अंतर करता है।

अर्धविराम वैकल्पिक हैं

निर्देश की प्रत्येक पंक्ति को कहा जाता है statement। जावास्क्रिप्ट में अर्धविराम वैकल्पिक हैं।

उदाहरण

console.log("hello world") 
console.log("We are learning ES6")

एक एकल पंक्ति में कई कथन हो सकते हैं। हालाँकि, इन कथनों को एक अर्धविराम द्वारा अलग किया जाना चाहिए।

जावास्क्रिप्ट में टिप्पणियाँ

Commentsएक कार्यक्रम की पठनीयता में सुधार करने का एक तरीका है। किसी प्रोग्राम के बारे में अतिरिक्त जानकारी शामिल करने के लिए टिप्पणियों का उपयोग किया जा सकता है जैसे कोड के लेखक, किसी फ़ंक्शन / निर्माण के बारे में संकेत, आदि टिप्पणियाँ संकलक द्वारा अनदेखा की जाती हैं।

जावास्क्रिप्ट निम्न प्रकार की टिप्पणियों का समर्थन करता है -

  • Single-line comments (//) - // और पंक्ति के अंत के बीच के किसी भी पाठ को एक टिप्पणी के रूप में माना जाता है।

  • Multi-line comments (/* */) - इन टिप्पणियों में कई लाइनें हो सकती हैं।

उदाहरण

//this is single line comment  
/* This is a  
Multi-line comment 
*/

आपका पहला जावास्क्रिप्ट कोड

आइए हम पारंपरिक "हैलो वर्ल्ड" उदाहरण से शुरू करें।

var message = "Hello World" 
console.log(message)

कार्यक्रम का विश्लेषण इस प्रकार किया जा सकता है -

  • लाइन 1 नाम संदेश द्वारा एक चर घोषित करता है। चर एक कार्यक्रम में मूल्यों को संग्रहीत करने के लिए एक तंत्र है।

  • लाइन 2 प्रॉम्प्ट पर वैरिएबल के मान को प्रिंट करता है। यहाँ, कंसोल टर्मिनल विंडो को संदर्भित करता है। फ़ंक्शन लॉग () का उपयोग स्क्रीन पर पाठ प्रदर्शित करने के लिए किया जाता है।

संहिता को निष्पादित करना

हम अपने कोड को निष्पादित करने के लिए Node.js का उपयोग करेंगे।

  • Step 1 - फ़ाइल को Test.js के रूप में सहेजें

  • Step 2 - Visual Studio Code के प्रोजेक्ट-एक्सप्लोरर विंडो में वर्किंग ऑप्शन के तहत Test.js फाइल पर राइट क्लिक करें।

  • Step 3 - कमांड प्रॉम्प्ट विकल्प में ओपन का चयन करें।

  • Step 4 - नोड की टर्मिनल विंडो में निम्न कमांड टाइप करें।

node Test.js

निम्न आउटपुट फ़ाइल के सफल निष्पादन पर प्रदर्शित होता है।

Hello World

नोड.जेएस और जेएस / ईएस 6

ECMAScript 2015 (ES6) सुविधाओं को तीन समूहों में वर्गीकृत किया गया है -

  • For Shipping - ये ऐसी विशेषताएं हैं जो V8 को स्थिर मानती हैं।

  • Staged Features - ये लगभग पूरी हो चुकी विशेषताएं हैं लेकिन V8 टीम द्वारा स्थिर नहीं मानी जाती हैं।

  • In Progress - इन सुविधाओं का उपयोग केवल परीक्षण उद्देश्यों के लिए किया जाना चाहिए।

सुविधाओं की पहली श्रेणी पूरी तरह से समर्थित है और डिफ़ॉल्ट रूप से नोड द्वारा चालू की गई है। मंचित विशेषताओं को निष्पादित करने के लिए एक रनटाइम - - सद्भाव ध्वज की आवश्यकता होती है।

Node.js के लिए घटक विशिष्ट CLI झंडे की एक सूची यहां पाई जा सकती है - https://nodejs.org/api/cli.html

द स्ट्रिक मोड

ECMAScript विनिर्देश के पांचवें संस्करण ने स्ट्रिक्ट मोड की शुरुआत की। स्ट्रिक्ट मोड जावास्क्रिप्ट पर बाधा की एक परत लगाता है। यह सामान्य जावास्क्रिप्ट शब्दार्थ में कई बदलाव करता है।

कोड को निम्न सहित स्ट्रिक्ट मोड में काम करने के लिए परिवर्तित किया जा सकता है -

// Whole-script strict mode syntax 
"use strict"; 
 v = "Hi!  I'm a strict mode script!";  // ERROR: Variable v is not declared

उपरोक्त स्निपेट में, पूरा कोड जावास्क्रिप्ट के विवश रूप से चलता है।

जावास्क्रिप्ट भी प्रतिबंधित करने की अनुमति देता है, एक फ़ंक्शन के रूप में ब्लॉक के दायरे में सख्त मोड। इसका वर्णन इस प्रकार है -

v = 15 
function f1() { 
   "use strict"; 
   var v = "Hi!  I'm a strict mode script!"; 
}

उपरोक्त स्निपेट में, फ़ंक्शन के बाहर कोई भी कोड गैर-सख्त मोड में चलेगा। फ़ंक्शन के भीतर सभी कथनों को स्ट्रिक्ट मोड में निष्पादित किया जाएगा।

ES6 और उत्थापन

जावास्क्रिप्ट इंजन, डिफ़ॉल्ट रूप से, घोषणाओं को शीर्ष पर ले जाता है। इस सुविधा को कहा जाता हैhoisting। यह सुविधा चर और कार्यों पर लागू होती है। उत्थापन जावास्क्रिप्ट को घोषित होने से पहले एक घटक का उपयोग करने की अनुमति देता है। हालाँकि, उत्थापन की अवधारणा उन लिपियों पर लागू नहीं होती है जो स्ट्रिक्ट मोड में चलाई जाती हैं।

परिवर्तनीय उत्थापन और कार्य उत्थापन को बाद के अध्यायों में समझाया गया है।

variable, परिभाषा के अनुसार, "मेमोरी में एक नामित स्थान" है जो मूल्यों को संग्रहीत करता है। दूसरे शब्दों में, यह एक कार्यक्रम में मूल्यों के लिए एक कंटेनर के रूप में कार्य करता है। चर नाम कहलाते हैंidentifiers। एक पहचानकर्ता के नामकरण नियम निम्नलिखित हैं -

  • पहचानकर्ता कीवर्ड नहीं हो सकते।

  • पहचानकर्ताओं में अक्षर और संख्या हो सकती है।

  • पहचानकर्ता में अंडरस्कोर (_) और डॉलर ($) चिह्न को छोड़कर स्थान और विशेष वर्ण नहीं हो सकते।

  • परिवर्तनीय नाम एक संख्या से शुरू नहीं हो सकते हैं।

सिंटैक्स टाइप करें

इसका उपयोग करने से पहले एक चर घोषित किया जाना चाहिए। ES5 सिंटैक्स का उपयोग कियाvarकीवर्ड समान प्राप्त करने के लिए। एक चर घोषित करने के लिए ES5 सिंटैक्स निम्नानुसार है।

//Declaration using var keyword 
var  variable_name

ES6 निम्नलिखित चर घोषणा सिंटैक्स का परिचय देता है -

  • का उपयोग करते हुए।
  • कास्ट का उपयोग करना।

Variable initializationचर में मान को संग्रहीत करने की प्रक्रिया को संदर्भित करता है। एक चर या तो इसकी घोषणा के समय या बाद के समय में शुरू किया जा सकता है।

वैरिएबल घोषित करने और आरंभ करने के लिए पारंपरिक ES5 प्रकार का सिंटैक्स निम्नानुसार है -

//Declaration using var keyword 
var variable_name = value

उदाहरण: चर का उपयोग करना

var name = "Tom" 
console.log("The value in the variable is: "+name)

उपरोक्त उदाहरण एक चर घोषित करता है और इसके मूल्य को प्रिंट करता है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

The value in the variable is Tom

जावास्क्रिप्ट और गतिशील टाइपिंग

जावास्क्रिप्ट एक गैर-टाइप भाषा है। इसका मतलब है कि जावास्क्रिप्ट चर किसी भी डेटा प्रकार का मान रख सकता है। कई अन्य भाषाओं के विपरीत, आपको चर घोषणा के दौरान जावास्क्रिप्ट को यह बताने की जरूरत नहीं है कि चर किस प्रकार का मूल्य रखेगा। किसी प्रोग्राम के निष्पादन के दौरान एक वैरिएबल का मान बदल सकता है और जावास्क्रिप्ट स्वचालित रूप से इसकी देखभाल करता है। इस सुविधा को कहा जाता हैdynamic typing

जावास्क्रिप्टयोग्य स्कोप

एक चर का दायरा आपके कार्यक्रम का क्षेत्र है जिसमें इसे परिभाषित किया गया है। परंपरागत रूप से, जावास्क्रिप्ट केवल दो स्कोपों ​​को परिभाषित करता है-वैश्विक और स्थानीय।

  • Global Scope - वैश्विक दायरे वाले एक चर को जावास्क्रिप्ट कोड के किसी भी हिस्से के भीतर से एक्सेस किया जा सकता है।

  • Local Scope - एक स्थानीय क्षेत्र के साथ एक चर एक समारोह के भीतर से पहुँचा जा सकता है जहाँ यह घोषित किया जाता है।

उदाहरण: वैश्विक बनाम स्थानीय चर

निम्न उदाहरण नाम से दो चर घोषित करता है num - एक फंक्शन (ग्लोबल स्कोप) के बाहर और दूसरा फंक्शन (लोकल स्कोप) के भीतर।

var num = 10 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) 
} 
console.log("value of num outside test() "+num) 
test()

चर जब फ़ंक्शन के भीतर संदर्भित होता है, तो स्थानीय रूप से स्कोप किए गए चर का मान प्रदर्शित करता है। हालांकि, चरnum जब फ़ंक्शन के बाहर एक्सेस किया जाता है, तो वैश्विक रूप से स्कोप की गई आवृत्ति वापस आती है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

value of num outside test() 10
value of num in test() 100

ES6 एक नया चर क्षेत्र परिभाषित करता है - ब्लॉक गुंजाइश।

द लेट एंड ब्लॉक स्कोप

ब्लॉक स्कोप एक वैरिएबल की पहुंच को उस ब्लॉक तक पहुंचाता है जिसमें यह घोषित किया गया है। varकीवर्ड वेरिएबल को फंक्शन स्कोप प्रदान करता है। वर कीवर्ड के विपरीत,let कीवर्ड स्क्रिप्ट को वैरिएबल तक पहुँच को निकटतम एन्क्लोज़िंग ब्लॉक तक सीमित रखने की अनुमति देता है।

"use strict" 
function test() { 
   var num = 100 
   console.log("value of num in test() "+num) { 
      console.log("Inner Block begins") 
      let num = 200 
      console.log("value of num : "+num)  
   } 
} 
test()

स्क्रिप्ट एक चर घोषित करती है numकिसी फ़ंक्शन के स्थानीय दायरे में और लेट कीवर्ड का उपयोग करके इसे फिर से ब्लॉक में घोषित करता है। स्थानीय रूप से स्कोप किए गए वैरिएबल का मान तब प्रिंट किया जाता है, जब वैरिएबल को ब्लॉक के बाहर एक्सेस किया जाता है, जबकि ब्लॉक स्कॉप्ड वेरिएबल को इनर ब्लॉक के भीतर रेफर किया जाता है।

Note - सख्त मोड जावास्क्रिप्ट के प्रतिबंधित संस्करण में चुनने का एक तरीका है।

निम्नलिखित आउटपुट सफल निष्पादन पर प्रदर्शित किया जाता है।

value of num in test() 100 
Inner Block begins 
value of num : 200

उदाहरण: चलो v / s var

var no = 10; 
var no = 20; 
console.log(no);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

20

हमें उसी कोड का उपयोग करके फिर से लिखना चाहिए let कीवर्ड।

let no = 10; 
let no = 20; 
console.log(no);

उपरोक्त कोड एक त्रुटि फेंक देगा: पहचानकर्ता 'नहीं' पहले ही घोषित किया जा चुका है। लेटर कीवर्ड का उपयोग करके घोषित किसी भी चर को ब्लॉक स्कोप सौंपा गया है।

चलो और ब्लॉक स्तर की सुरक्षा

अगर हम घोषणा करने की कोशिश करते हैं letएक ही ब्लॉक के भीतर दो बार चर, यह एक त्रुटि फेंक देंगे। निम्नलिखित उदाहरण पर विचार करें -

<script>
   let balance = 5000 // number type
   console.log(typeof balance)
   let balance = {message:"hello"} // changing number to object type
   console.log(typeof balance)
</script>

उपरोक्त कोड के परिणामस्वरूप निम्न त्रुटि होगी -

Uncaught SyntaxError: Identifier 'balance' has already been declared

चलो और कई ब्लॉक

हालाँकि, वही let चर का उपयोग किसी भी सिंटैक्स त्रुटियों के बिना विभिन्न ब्लॉक स्तर के स्कोप में किया जा सकता है।

उदाहरण

<script>
   let count = 100
   for (let count = 1;count <= 10;count++){
      //inside for loop brackets ,count value starts from 1
      console.log("count value inside loop is ",count);
   }
   //outside for loop brackets ,count value is 100
   console.log("count value after loop is",count);

   if(count == 100){
      //inside if brackets ,count value is 50
      let count = 50;
      console.log("count inside if block",count);
   }
   console.log(count);
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

count value inside loop is 1
count value inside loop is 2
count value inside loop is 3
count value inside loop is 4
count value inside loop is 5
count value inside loop is 6
count value inside loop is 7
count value inside loop is 8
count value inside loop is 9
count value inside loop is 10
count value after loop is 100
count inside if block 50
100

कास्ट

constघोषणा मूल्य के लिए केवल-पढ़ने के लिए संदर्भ बनाता है। इसका मतलब यह नहीं है कि यह जो मूल्य रखता है वह अपरिवर्तनीय है, बस यह कि चर पहचानकर्ता को आश्वस्त नहीं किया जा सकता है। कॉन्स्टेंट ब्लॉक-स्कोप्ड हैं, बहुत कुछ वैरिएबल जैसे लेट स्टेटमेंट का उपयोग करके परिभाषित किया गया है। किसी स्थिरांक का मान पुनः असाइनमेंट के माध्यम से नहीं बदल सकता है, और इसे फिर से घोषित नहीं किया जा सकता है।

निम्नलिखित नियमों का उपयोग कर घोषित एक चर के लिए सही है const कीवर्ड -

  • स्थिरांक को फिर से असाइन नहीं किया जा सकता है।
  • एक स्थिरांक फिर से घोषित नहीं किया जा सकता है।
  • एक स्थिरांक को इनिशियलाइज़र की आवश्यकता होती है। इसका अर्थ यह है कि इसकी घोषणा के दौरान स्थिरांक को प्रारंभिक रूप दिया जाना चाहिए।
  • में निर्दिष्ट मान const परिवर्तनशील है।

उदाहरण

const x = 10
x = 12 // will result in an error!!

उपरोक्त कोड एक त्रुटि लौटाएगा क्योंकि स्थिरांक को मान पुन: असाइन नहीं किया जा सकता है। स्थिरांक चर अपरिवर्तनीय हैं।

स्थिरांक अपरिवर्तनीय हैं

उपयोग किए गए घोषित चर के विपरीत let कीवर्ड, constantsअपरिवर्तनीय हैं। इसका मतलब है कि इसका मूल्य नहीं बदला जा सकता है। उदाहरण के लिए, यदि हम निरंतर चर के मान को बदलने का प्रयास करते हैं, तो एक त्रुटि प्रदर्शित की जाएगी।

<script>
   let income = 100000
   const INTEREST_RATE = 0.08
   income += 50000 // mutable
   console.log("changed income value is ",income)
   INTEREST_RATE += 0.01
   console.log("changed rate is ",INTEREST_RATE) //Error: not mutable
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

changed income value is 150000
Uncaught TypeError: Assignment to constant variable

कास्ट और सरणियाँ

निम्नलिखित उदाहरण से पता चलता है कि कैसे एक अपरिवर्तनीय सरणी बनाई जाती है। नए तत्वों को सरणी में जोड़ा जा सकता है। हालाँकि, सरणी को पुनर्संरचना में परिणाम के रूप में नीचे दिखाया गया है -

<script>
   const DEPT_NOS = [10,20,30,50]
   DEPT_NOS.push(40)
   console.log('dept numbers is ',DEPT_NOS)

   const EMP_IDS = [1001,1002,1003]
   console.log('employee ids',EMP_IDS)
   //re assigning variable employee ids
   EMP_IDS = [2001,2002,2003]
   console.log('employee ids after changing',EMP_IDS)
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

dept numbers is (5) [10, 20, 30, 50, 40]
employee ids (3) [1001, 1002, 1003]
Uncaught TypeError: Assignment to constant variable.

वार कीवर्ड

ईएस 6 से पहले, ए varकीवर्ड का उपयोग जावास्क्रिप्ट में एक चर घोषित करने के लिए किया गया था। चर का उपयोग कर की घोषणा कीvarब्लॉक स्तर की गुंजाइश का समर्थन नहीं करते। इसका मतलब है कि अगर एक चर एक लूप में घोषित किया गया है याif block यह लूप के बाहर पहुँचा जा सकता है या if block। इसका कारण यह है चर का उपयोग कर की घोषणा कीvar कीवर्ड समर्थन उत्थापन।

var और उत्थापन

Variable hoistingघोषित होने से पहले ही जावास्क्रिप्ट प्रोग्राम में वैरिएबल के उपयोग की अनुमति देता है। इस तरह के चरों को आरंभीकृत किया जाएगाundefinedडिफ़ॉल्ट रूप से। जावास्क्रिप्ट रनटाइम चर घोषणाओं के लिए स्कैन करेगा और उन्हें फ़ंक्शन या स्क्रिप्ट के शीर्ष पर रखेगा। चर के साथ घोषितvarकीवर्ड शीर्ष पर फहराया जाता है। निम्नलिखित उदाहरण पर विचार करें -

<script>
   variable company is hoisted to top , var company = undefined
   console.log(company); // using variable before declaring
   var company = "TutorialsPoint"; // declare and initialized here
   console.log(company);
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

undefined
TutorialsPoint

var और ब्लॉक स्कोप

block scopeजिस खंड में यह घोषित किया गया है, उसके लिए चर की पहुंच को प्रतिबंधित करता है। varकीवर्ड वेरिएबल को फंक्शन स्कोप प्रदान करता है। चर का उपयोग कर की घोषणा कीvarकीवर्ड में ब्लॉक स्कोप नहीं है। निम्नलिखित उदाहरण पर विचार करें -

<script>
   //hoisted to top ; var i = undefined
   for (var i = 1;i <= 5;i++){
      console.log(i);
   }
   console.log("after the loop i value is "+i);
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

1
2
3
4
5
after the loop i value is 6

चर i का उपयोग कर पाश के लिए अंदर घोषित किया गया है varकीवर्ड। चर मैं पाश के बाहर सुलभ है। हालाँकि, कई बार, किसी ब्लॉक के भीतर वैरिएबल की पहुंच को प्रतिबंधित करने की आवश्यकता हो सकती है। हम उपयोग नहीं कर सकतेvarइस परिदृश्य में कीवर्ड। ES6 परिचयlet इस सीमा को पार करने के लिए खोजशब्द।

var और ब्लॉक स्तर की सुरक्षा

अगर हम ऐसा ही घोषित करते हैं variable दो बार का उपयोग कर var keywordएक ब्लॉक के भीतर, संकलक एक त्रुटि नहीं करेगा। हालाँकि, इससे रनटाइम पर अनपेक्षित तार्किक त्रुटियाँ हो सकती हैं।

<script>
   var balance = 5000
   console.log(typeof balance)
   var balance = {message:"hello"}
   console.log(typeof balance)
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

number
object

एक expressionएक विशेष प्रकार का कथन है जो किसी मान का मूल्यांकन करता है। हर अभिव्यक्ति से बना है -

  • Operands - डेटा का प्रतिनिधित्व करता है।

  • Operator - परिभाषित करता है कि एक मूल्य का उत्पादन करने के लिए ऑपरेंड को कैसे संसाधित किया जाएगा।

निम्नलिखित अभिव्यक्ति पर विचार करें- 2 + 3. यहां अभिव्यक्ति में 2 और 3 ऑपरेंड हैं और प्रतीक + (प्लस) ऑपरेटर है। जावास्क्रिप्ट निम्न प्रकार के ऑपरेटरों का समर्थन करता है -

  • अंकगणितीय आपरेटर
  • लॉजिकल ऑपरेटर्स
  • संबंधपरक संकारक
  • बिटवाइज ऑपरेटर
  • असाइनमेंट ऑपरेटर
  • टर्नरी / सशर्त ऑपरेटर
  • स्ट्रिंग ऑपरेटरों
  • ऑपरेटर टाइप करें
  • शून्य संचालक

अंकगणितीय आपरेटर

मानों को चर में मान लें a तथा b क्रमशः 10 और 5 हैं।

उदाहरण दिखाएं

ऑपरेटर समारोह उदाहरण
+ Addition

परिचालकों का योग लौटाता है।

a + b 15 है
- Subtraction

मूल्यों का अंतर लौटाता है।

एब 5 है
* Multiplication

मूल्यों का उत्पाद लौटाता है।

a * b 50 है
/ Division

विभाजन ऑपरेशन करता है और भागफल लौटाता है।

a / b 2 है
% Modulus

एक विभाजन करता है और शेष रिटर्न करता है।

अ% ख 0 र
++ Increment

एक-एक करके चर का मान बढ़ाता है।

एक ++ 11 है
- Decrement

चर का मान एक से घटाता है।

ए - 9 है

संबंधपरक संकारक

रिलेशनल ऑपरेटर्स दो संस्थाओं के बीच संबंधों के प्रकार का परीक्षण या परिभाषित करते हैं। रिलेशनल ऑपरेटर्स एक बूलियन मान लौटाते हैं, अर्थात सही / गलत।

मान लें कि A का मान 10 है और B का मान 20 है।

उदाहरण दिखाएं

ऑपरेटर्स विवरण उदाहरण
> से अधिक (ए> बी) गलत है
< के मुकाबले कम (ए <बी) सच है
> = इससे बड़ा या इसके बराबर (ए> = बी) गलत है
<= से कम या उसके बराबर (ए <= बी) सच है
== समानता (ए == बी) गलत है
! = बराबर नहीं (ए! = बी) सच है

लॉजिकल ऑपरेटर्स

लॉजिकल ऑपरेटर्स का उपयोग दो या अधिक स्थितियों के संयोजन के लिए किया जाता है। लॉजिकल ऑपरेटर भी, बूलियन मान लौटाते हैं। चर A का मान 10 है और B का मान 20 है।

उदाहरण दिखाएं ।

ऑपरेटर्स विवरण उदाहरण
&& And

ऑपरेटर तभी सही लौटाता है, जब सभी अभिव्यक्तियाँ सही हो।

(A> 10 && B> 10) गलत है
|| Or

यदि ऑपरेटर निर्दिष्ट रिटर्न में से कम से कम एक सही है तो ऑपरेटर सही लौटाता है।

(ए> 10 || बी> 10) सच है
! Not

ऑपरेटर अभिव्यक्ति के परिणाम का प्रतिलोम लौटाता है। उदाहरण के लिए:! (7> 5) गलत है।

! (A> 10) सत्य है

बिटवाइज ऑपरेटर्स

जावास्क्रिप्ट निम्न बिटवाइज ऑपरेटरों का समर्थन करता है। निम्न तालिका जावास्क्रिप्ट बिट्स ऑपरेटरों को सारांशित करती है।

उदाहरण दिखाएं ।

ऑपरेटर्स प्रयोग विवरण
बिटवाइज़ और ए और बी प्रत्येक बिट स्थिति में एक देता है जिसके लिए दोनों ऑपरेंड के संगत बिट्स होते हैं
बिटवार या ए | ख प्रत्येक बिट स्थिति में एक देता है जिसके लिए दोनों या दोनों ऑपरेंड के संबंधित बिट्स होते हैं
बिटवाइज़ XOR ^ बी प्रत्येक बिट स्थिति में एक लौटाता है, जिसके लिए दोनों ऑपरेंड एक समान नहीं होते हैं
बिटवाइज़ नहीं ~ ए इसके ऑपरेंड के बिट्स को निष्क्रिय करता है
बायां शिफ्ट a << b बाईं ओर बाइनरी प्रतिनिधित्व बी (<32) बिट्स में बदलाव, दाएं से शून्य में स्थानांतरण
साइन-प्रोपेगेटिंग राइट शिफ्ट एक >> बी बाइनरी प्रतिनिधित्व बी (<32) बिट्स को दाईं ओर शिफ्ट करना, बिट्स को स्थानांतरित करना बंद कर दिया गया
जीरो-फिल राइट शिफ्ट एक >>> बी एक द्विआधारी प्रतिनिधित्व बी (<32) बिट्स को दाईं ओर शिफ्ट करता है, बिट्स को स्थानांतरित करना छोड़ दिया जाता है, और बाईं ओर से शून्य में स्थानांतरण होता है

असाइनमेंट ऑपरेटर्स

निम्न तालिका असाइनमेंट ऑपरेटरों को सारांशित करती है।

उदाहरण दिखाएं ।

अनु क्रमांक ऑपरेटर और विवरण
1

= (Simple Assignment)

राइट साइड ऑपरेंड से लेफ्ट साइड ऑपरेंड तक वैल्यू असाइन करता है।

Example - C = A + B A + B के C में मान प्रदान करेगा

2

+= (Add and Assignment)

यह बाएं ऑपरेंड में दाईं ओर ऑपरेंड जोड़ता है और परिणाम को बाएं ऑपरेंड में असाइन करता है।

Example - C + = A C = C + A के बराबर है

3

-= (Subtract and Assignment)

यह बाएं ऑपरेंड से दाएं ऑपरेंड को घटाता है और लेफ्ट ऑपरेंड को रिजल्ट सौंपता है।

Example C - = A C = C - A के बराबर है

4

*= (Multiply and Assignment)

यह बाएं ऑपरेंड के साथ दाएं ऑपरेंड को गुणा करता है और परिणाम को बाएं ऑपरेंड में असाइन करता है।

Example C * = A C = C * A के बराबर है

5

/= (Divide and Assignment)

यह बाएं ऑपरेंड को दाएं ऑपरेंड के साथ विभाजित करता है और परिणाम को बाएं ऑपरेंड को सौंपता है।

Note - बिटवाइज ऑपरेटरों के लिए भी यही तर्क लागू होता है, इसलिए वे << =, >> =, >> =, & =, = = और ^ = बन जाएंगे।

विविध संचालक

निम्नलिखित कुछ विविध ऑपरेटर हैं।

निषेध ऑपरेटर (-)

मान का चिह्न बदलता है। निम्नलिखित कार्यक्रम उसी का एक उदाहरण है।

var x = 4 
var y = -x; 
console.log("value of x: ",x); //outputs 4 
console.log("value of y: ",y); //outputs -4

निम्नलिखित आउटपुट उपरोक्त कार्यक्रम के सफल निष्पादन पर प्रदर्शित होता है।

value of x: 4 
value of y: -4

स्ट्रिंग ऑपरेटर्स: कॉन्टैक्शन ऑपरेटर (+)

स्ट्रिंग के लिए लागू होने वाला + ऑपरेटर दूसरे स्ट्रिंग को पहले में जोड़ता है। निम्नलिखित कार्यक्रम इस अवधारणा को समझने में मदद करता है।

var msg = "hello"+"world" 
console.log(msg)

निम्नलिखित आउटपुट उपरोक्त कार्यक्रम के सफल निष्पादन पर प्रदर्शित होता है।

helloworld

संघटन ऑपरेशन स्ट्रिंग्स के बीच एक स्थान नहीं जोड़ता है। एक ही कथन में कई तार समेटे जा सकते हैं।

सशर्त संचालक ()

इस ऑपरेटर का उपयोग सशर्त अभिव्यक्ति का प्रतिनिधित्व करने के लिए किया जाता है। सशर्त ऑपरेटर को कभी-कभी टर्नरी ऑपरेटर भी कहा जाता है। निम्नलिखित वाक्य रचना है।

Test ? expr1 : expr2

कहाँ पे,

Test - सशर्त अभिव्यक्ति का संदर्भ देता है

expr1 - यदि शर्त सही है तो मान लौटाया जाता है

expr2 - यदि स्थिति झूठी है तो मान लौटाया जाता है

Example

var num = -2 
var result = num > 0 ?"positive":"non-positive" 
console.log(result)

लाइन 2 यह जांचती है कि क्या चर संख्या में मूल्य शून्य से अधिक है। यदि अंक को शून्य से अधिक मान पर सेट किया जाता है, तो यह स्ट्रिंग को "सकारात्मक" और "गैर-सकारात्मक" स्ट्रिंग लौटाता है।

निम्नलिखित आउटपुट उपरोक्त कार्यक्रम के सफल निष्पादन पर प्रदर्शित होता है।

non-positive

टाइपो ऑपरेटर

यह एक यूनियर ऑपरेटर है। यह ऑपरेटर ऑपरेटर का डेटा प्रकार लौटाता है। निम्न तालिका डेटा प्रकारों को सूचीबद्ध करती है और मानों की वापसी होती हैtypeof जावास्क्रिप्ट में ऑपरेटर।

प्रकार स्ट्रिंग टाइपफ़ द्वारा लौटाया गया
संख्या "संख्या"
तार "स्ट्रिंग"
बूलियन "बूलियन"
वस्तु "वस्तु"

निम्न उदाहरण कोड आउटपुट के रूप में संख्या प्रदर्शित करता है।

var num = 12 
console.log(typeof num); //output: number

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

number

फैला हुआ संचालक

ES6 नामक एक नया ऑपरेटर प्रदान करता है spread operator। प्रसार ऑपरेटर को तीन डॉट्स "..." द्वारा दर्शाया गया है। प्रसार ऑपरेटर किसी सरणी को अलग-अलग सरणी तत्वों में परिवर्तित करता है।

प्रसार ऑपरेटर और समारोह

निम्न उदाहरण एक फ़ंक्शन में प्रसार ऑपरेटरों के उपयोग को दिखाता है

<script>
   function addThreeNumbers(a,b,c){
      return a+b+c;
   }
   const arr = [10,20,30]
   console.log('sum is :',addThreeNumbers(...arr))
   console.log('sum is ',addThreeNumbers(...[1,2,3]))
</script>

उपरोक्त कोड का आउटपुट नीचे देखा जाएगा -

sum is : 60
sum is 6

प्रसार ऑपरेटर और एरे कॉपी और कॉनैट

प्रसार ऑपरेटर का उपयोग एक सरणी को दूसरे में कॉपी करने के लिए किया जा सकता है। इसका उपयोग दो या दो से अधिक सरणियों को जोड़ने के लिए भी किया जा सकता है। यह नीचे दिए गए उदाहरण में दिखाया गया है -

उदाहरण

<script>
   //copy array using spread operator
   let source_arr = [10,20,30]
   let dest_arr = [...source_arr]
   console.log(dest_arr)
	
   //concatenate two arrays
   let arr1 = [10,20,30]
   let arr2 =[40,50,60]
   let arr3 = [...arr1,...arr2]
   console.log(arr3)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

[10, 20, 30]
[10, 20, 30, 40, 50, 60]

प्रसार संचालक और वस्तु प्रतिलिपि और संघनन

प्रसार ऑपरेटर का उपयोग एक वस्तु को दूसरे में कॉपी करने के लिए किया जा सकता है। इसका उपयोग दो या दो से अधिक वस्तुओं को जोड़ने के लिए भी किया जा सकता है। यह नीचे दिए गए उदाहरण में दिखाया गया है -

<script>
   //copy object
   let student1 ={firstName:'Mohtashim',company:'TutorialsPoint'}
   let student2 ={...student1}
   console.log(student2)
   //concatenate objects
   let student3 = {lastName:'Mohammad'}
   let student4 = {...student1,...student3}
   console.log(student4)
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

{firstName: "Mohtashim", company: "TutorialsPoint"}
{firstName: "Mohtashim", company: "TutorialsPoint", lastName: "Mohammad"}

एक सशर्त / निर्णय लेने वाला निर्माण अनुदेश / निष्पादित होने से पहले एक शर्त का मूल्यांकन करता है।

जावास्क्रिप्ट में सशर्त निर्माण को निम्न तालिका में वर्गीकृत किया गया है।

अनु क्रमांक विवरण और विवरण
1 यदि कथन

एक 'अगर' कथन में बूलियन अभिव्यक्ति होती है, जिसके बाद एक या अधिक कथन होते हैं।

2 अगर ... और स्टेटमेंट

एक 'अगर' कथन को एक वैकल्पिक 'और' कथन द्वारा अनुसरण किया जा सकता है, जो बूलियन अभिव्यक्ति के गलत होने पर निष्पादित होता है।

3 बाकी .. अगर सीढ़ी / नेस्टेड हो तो स्टेटमेंट्स

अन्यथा ... यदि सीढ़ी कई स्थितियों का परीक्षण करने के लिए उपयोगी है। निम्नलिखित उसी का वाक्य विन्यास है।

4 स्विच ... केस स्टेटमेंट

स्विच स्टेटमेंट एक एक्सप्रेशन का मूल्यांकन करता है, एक केस क्लॉज के एक्सप्रेशन के मूल्य से मेल खाता है और उस केस से जुड़े स्टेटमेंट को निष्पादित करता है।

कई बार, कुछ निर्देशों को दोहराए जाने की आवश्यकता होती है। लूप्स ऐसा करने का एक आदर्श तरीका है। एक लूप निर्देशों का एक सेट दर्शाता है जिसे दोहराया जाना चाहिए। लूप के संदर्भ में, एक पुनरावृत्ति को एक के रूप में कहा जाता हैiteration

निम्नलिखित आंकड़ा छोरों के वर्गीकरण को दर्शाता है -

निश्चित लूप

एक लूप जिसका पुनरावृत्तियों की संख्या निश्चित है / निश्चित है उसे एक कहा जाता है definite loop। 'लूप के लिए' एक का कार्यान्वयन हैdefinite loop

for (initial_count_value; termination-condition; step) { 
   //statements
}

अनु क्रमांक निश्चित लूप और विवरण
1 'लूप' के लिए

लूप के लिए निर्दिष्ट समय के लिए कोड ब्लॉक निष्पादित करता है।

2 के लिए ... पाश में

के लिए ... पाश में एक वस्तु के गुणों के माध्यम से पाश करने के लिए प्रयोग किया जाता है।

3 लूप के लिए ...

लूप के लिए ... का उपयोग वस्तु शाब्दिक के बजाय पुनरावृत्तियों को पुनरावृत्त करने के लिए किया जाता है।

अनिश्चित लूप

अनिश्चित लूप का उपयोग तब किया जाता है जब एक लूप में पुनरावृत्तियों की संख्या अनिश्चित या अज्ञात होती है।

अनिश्चित लूप का उपयोग करके लागू किया जा सकता है -

अनु क्रमांक अनिश्चितकालीन लूप और विवरण
1 जबकि पाश

जबकि लूप हर बार उन निर्देशों को निष्पादित करता है जो निर्दिष्ट स्थिति सच का मूल्यांकन करता है।

2 लूप करते समय…

लूप करते समय लूप, जबकि लूप के समान होता है, सिवाय इसके कि ... लूप पहली बार लूप निष्पादित होने की स्थिति का मूल्यांकन नहीं करता है।

लूप नियंत्रण विवरण

अनु क्रमांक लूप नियंत्रण विवरण और विवरण
1 ब्रेक स्टेटमेंट

ब्रेक स्टेटमेंट का उपयोग किसी निर्माण से नियंत्रण हटाने के लिए किया जाता है।

2 जारी बयान

जारी बयान वर्तमान पुनरावृत्ति में बाद के बयानों को छोड़ देता है और नियंत्रण को लूप की शुरुआत में वापस ले जाता है।

फ्लो को नियंत्रित करने के लिए लेबल का उपयोग करना

labelबस एक पहचानकर्ता द्वारा पीछा किया जाता है एक बृहदान्त्र (:) जो एक बयान या कोड के एक ब्लॉक पर लागू होता है। एक लेबल के साथ इस्तेमाल किया जा सकता हैbreak तथा continue प्रवाह को अधिक सटीक रूप से नियंत्रित करने के लिए।

के बीच लाइन ब्रेक की अनुमति नहीं है ‘continue’ या ‘break’स्टेटमेंट और उसका लेबल नाम। साथ ही, लेबल नाम और संबद्ध लूप के बीच कोई अन्य कथन नहीं होना चाहिए

अनु क्रमांक लेबल और विवरण
1 ब्रेक के साथ लेबल

एक लेबल का उपयोग ब्रेक के साथ किया जा सकता है और प्रवाह को अधिक सटीक रूप से नियंत्रित करना जारी रख सकता है।

2 जारी रखें के साथ लेबल

लाइन ब्रेक को 'जारी' या 'ब्रेक' स्टेटमेंट और उसके लेबल नाम के बीच अनुमति नहीं है।

Functionsपठनीय, बनाए रखने योग्य और पुन: प्रयोज्य कोड के निर्माण खंड हैं। फ़ंक्शन कीवर्ड का उपयोग करके फ़ंक्शंस परिभाषित किए जाते हैं। मानक फ़ंक्शन को परिभाषित करने के लिए सिंटैक्स निम्नलिखित है।

function function_name() { 
   // function body 
}

फ़ंक्शन के निष्पादन को मजबूर करने के लिए, इसे कॉल करना होगा। इसे फंक्शन इनवोकेशन कहा जाता है। एक समारोह आह्वान करने के लिए वाक्य रचना निम्नलिखित है।

function_name()

उदाहरण: सरल कार्य परिभाषा

//define a  function 
function test() { 
   console.log("function called") 
} 
//call the function 
test()

उदाहरण एक फ़ंक्शन परीक्षण () को परिभाषित करता है। डेलिमिटर ({}) की एक जोड़ी फ़ंक्शन बॉडी को परिभाषित करती है। इसे भी कहा जाता हैfunction scope। इसके निष्पादन को बाध्य करने के लिए एक फ़ंक्शन को लागू किया जाना चाहिए।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

function called

कार्यों का वर्गीकरण

कार्यों को वर्गीकृत किया जा सकता है Returning तथा Parameterized कार्य करता है।

लौटने के कार्य

नियंत्रण वापस कॉल करने वाले के साथ-साथ मान भी लौटा सकता है। ऐसे कार्यों को रिटर्निंग फ़ंक्शन कहा जाता है।

निम्न फ़ंक्शन के लिए सिंटैक्स है।

function function_name() { 
   //statements 
   return value; 
}
  • रिटर्न स्टेटमेंट को रिटर्न स्टेटमेंट के साथ समाप्त होना चाहिए।

  • एक फ़ंक्शन सबसे अधिक मूल्य पर वापस आ सकता है। दूसरे शब्दों में, प्रति फ़ंक्शन केवल एक रिटर्न स्टेटमेंट हो सकता है।

  • फ़ंक्शन में रिटर्न स्टेटमेंट अंतिम स्टेटमेंट होना चाहिए।

निम्नलिखित कोड स्निपेट एक रिटर्निंग फ़ंक्शन का एक उदाहरण है -

function retStr() { 
   return "hello world!!!" 
}  
var val = retStr() 
console.log(val)

उपरोक्त उदाहरण एक फ़ंक्शन को परिभाषित करता है जो स्ट्रिंग "हैलो वर्ल्ड" लौटाता है !!! फोन करने वाले को। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

hello world!!!

परिमेय कार्य

पैरामीटर फ़ंक्शन के मानों को पारित करने के लिए एक तंत्र है। पैरामीटर फ़ंक्शन के हस्ताक्षर का एक हिस्सा बनाते हैं। पैरामीटर मान को इसके मंगलाचरण के दौरान फ़ंक्शन में पास किया जाता है। जब तक स्पष्ट रूप से निर्दिष्ट नहीं किया जाता है, तब तक फ़ंक्शन के लिए दिए गए मानों की संख्या निर्धारित मापदंडों की संख्या से मेल खाना चाहिए।

निम्नलिखित एक पैरामीटर फ़ंक्शन को परिभाषित करने वाला सिंटैक्स है।

function func_name( param1,param2 ,…..paramN) {   
   ...... 
   ...... 
}

Example − Parameterized Function

उदाहरण एक फ़ंक्शन को परिभाषित करता है जो दो मापदंडों को स्वीकार करता है n1 तथा n2और उनकी राशि को प्रिंट करता है। जब इसे लागू किया जाता है, तो पैरामीटर मान फ़ंक्शन में चला जाता है।

function add( n1,n2) { 
   var sum = n1 + n2 
   console.log("The sum of the values entered "+sum) 
} 
add(12,13)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

The sum of the values entered 25

डिफ़ॉल्ट फ़ंक्शन पैरामीटर

ईएस 6 में, एक फ़ंक्शन मापदंडों को डिफ़ॉल्ट मानों के साथ आरंभ करने की अनुमति देता है, अगर कोई मान इसे पारित नहीं किया जाता है या यह अपरिभाषित है। इसका वर्णन निम्नलिखित कोड में किया गया है।

function add(a, b = 1) { 
   return a+b; 
} 
console.log(add(4))

उपरोक्त फ़ंक्शन, डिफ़ॉल्ट रूप से b से 1 का मान सेट करता है। फ़ंक्शन हमेशा मान 1 को सहन करने के लिए पैरामीटर बी पर विचार करेगा जब तक कि मूल्य को स्पष्ट रूप से पारित नहीं किया जाता है। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

5

यदि फ़ंक्शन स्पष्ट रूप से मान पास करता है, तो पैरामीटर्स का डिफ़ॉल्ट मान अधिलेखित हो जाएगा।

function add(a, b = 1) { 
   return a + b; 
} 
console.log(add(4,2))

उपरोक्त कोड पैरामीटर बी के मूल्य को स्पष्ट रूप से 2 पर सेट करता है, जिससे इसका डिफ़ॉल्ट मान ओवरराइट हो जाता है। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

6

बेहतर समझ के लिए, हम नीचे दिए गए उदाहरण पर विचार करें।

उदाहरण 1

निम्न उदाहरण एक फ़ंक्शन को दर्शाता है जो दो मापदंडों को लेता है और उनकी राशि लौटाता है। दूसरे पैरामीटर का डिफ़ॉल्ट मान 10 होता है। इसका मतलब है, अगर कोई मान दूसरे पैरामीटर से पारित नहीं होता है, तो इसका मान 10 होगा।

<script>
   function addTwoNumbers(first,second = 10){
      console.log('first parameter is :',first)
      console.log('second parameter is :',second)
      return first+second;
   }

   console.log("case 1 sum:",addTwoNumbers(20)) // no value
   console.log("case 2 sum:",addTwoNumbers(2,3))
   console.log("case 3 sum:",addTwoNumbers())
   console.log("case 4 sum",addTwoNumbers(1,null))//null passed
   console.log("case 5 sum",addTwoNumbers(3,undefined))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

first parameter is : 20
second parameter is : 10
case 1 sum: 30
first parameter is : 2
second parameter is : 3
case 2 sum: 5
first parameter is : undefined
second parameter is : 10
case 3 sum: NaN
first parameter is : 1
second parameter is : null
case 4 sum 1
first parameter is : 3
second parameter is : 10
case 5 sum 13

उदाहरण 2

<script>
   let DEFAULT_VAL = 30
      function addTwoNumbers(first,second = DEFAULT_VAL){
         console.log('first parameter is :',first)
         console.log('second parameter is :',second)
         return first+second;
      }
      console.log("case 1 sum",addTwoNumbers(1))
      console.log("case 2 sum",addTwoNumbers(3,undefined))
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

first parameter is : 1
second parameter is : 30
case 1 sum 31
first parameter is : 3
second parameter is : 30
case 2 sum 33

बाकी पैरामीटर

बाकी पैरामीटर जावा में चर तर्कों के समान हैं। बाकी पैरामीटर उन मानों की संख्या को प्रतिबंधित नहीं करते हैं जिन्हें आप किसी फ़ंक्शन में पास कर सकते हैं। हालाँकि, दिए गए मान सभी एक ही प्रकार के होने चाहिए। दूसरे शब्दों में, बाकी पैरामीटर एक ही प्रकार के कई तर्कों के लिए प्लेसहोल्डर के रूप में कार्य करते हैं।

बाकी पैरामीटर घोषित करने के लिए, पैरामीटर नाम तीन अवधियों के साथ उपसर्ग करता है, जिसे प्रसार ऑपरेटर के रूप में जाना जाता है। निम्न उदाहरण उसी का चित्रण करता है।

function fun1(...params) { 
   console.log(params.length); 
}  
fun1();  
fun1(5); 
fun1(5, 6, 7);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

0 
1 
3

Note - बाकी पैरामीटर फ़ंक्शन के पैरामीटर सूची में अंतिम होना चाहिए।

अनाम क्रिया

ऐसे फ़ंक्शंस जो किसी पहचानकर्ता (फ़ंक्शन नाम) के लिए बाध्य नहीं हैं, उन्हें अनाम फ़ंक्शंस कहा जाता है। इन कार्यों को गतिशील रूप से रनटाइम पर घोषित किया जाता है। अनाम फ़ंक्शंस इनपुट स्वीकार कर सकते हैं और आउटपुट वापस कर सकते हैं, जैसे कि मानक फ़ंक्शंस करते हैं। एक अनाम फ़ंक्शन आमतौर पर इसकी प्रारंभिक रचना के बाद सुलभ नहीं है।

चर को एक अनाम फ़ंक्शन सौंपा जा सकता है। ऐसी अभिव्यक्ति को ए कहा जाता हैfunction expression

अनाम फ़ंक्शन के लिए सिंटैक्स निम्नलिखित है।

var res = function( [arguments] ) { ... }

Example − Anonymous Function

var f = function(){ return "hello"} 
console.log(f())

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

hello

Example − Anonymous Parameterized Function

var func = function(x,y){ return x*y }; 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result) 
} 
product()

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

The product : 200

समारोह निर्माता

फ़ंक्शन स्टेटमेंट एक नए फ़ंक्शन को परिभाषित करने का एकमात्र तरीका नहीं है; आप नए ऑपरेटर के साथ फ़ंक्शन () कंस्ट्रक्टर का उपयोग करके अपने फ़ंक्शन को गतिशील रूप से परिभाषित कर सकते हैं।

नए ऑपरेटर के साथ फ़ंक्शन () कंस्ट्रक्टर का उपयोग करके फ़ंक्शन बनाने के लिए सिंटैक्स निम्नलिखित है।

var variablename = new Function(Arg1, Arg2..., "Function Body");

फंक्शन () कंस्ट्रक्टर किसी भी संख्या में स्ट्रिंग तर्क की अपेक्षा करता है। अंतिम तर्क फ़ंक्शन का निकाय है - इसमें मनमाने ढंग से जावास्क्रिप्ट स्टेटमेंट हो सकते हैं, जो अर्धविराम द्वारा एक दूसरे से अलग होते हैं।

फ़ंक्शन () निर्माता किसी भी तर्क को पारित नहीं करता है जो उस फ़ंक्शन के लिए एक नाम निर्दिष्ट करता है जो इसे बनाता है।

Example − Function Constructor

var func = new Function("x", "y", "return x*y;"); 
function product() { 
   var result; 
   result = func(10,20); 
   console.log("The product : "+result)
} 
product()

उपरोक्त उदाहरण में, फ़ंक्शन () निर्माता का उपयोग एक अनाम फ़ंक्शन को परिभाषित करने के लिए किया जाता है। फ़ंक्शन दो मापदंडों को स्वीकार करता है और उनके उत्पाद को लौटाता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

The product : 200

पुनरावर्तन और जावास्क्रिप्ट कार्य

पुनरावृत्ति एक ऑपरेशन पर पुनरावृत्ति करने के लिए एक तकनीक है, जिसके परिणामस्वरूप एक फ़ंक्शन कॉल होता है जब तक कि यह एक परिणाम पर नहीं आता। जब आप लूप के भीतर से अलग-अलग मापदंडों के साथ एक ही फ़ंक्शन को बार-बार कॉल करने की आवश्यकता होती है, तो पुनरावृत्ति सबसे अच्छा लागू होती है।

Example − Recursion

function factorial(num) { 
   if(num <= 0) { 
      return 1; 
   } else { 
      return (num * factorial(num-1)  ) 
   } 
} 
console.log(factorial(6))

उपरोक्त उदाहरण में फ़ंक्शन स्वयं को कॉल करता है। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

720

Example − Anonymous Recursive Function

(function() { 
   var msg = "Hello World" 
   console.log(msg)
})()

फ़ंक्शन स्वयं को कोष्ठक () की एक जोड़ी का उपयोग करके कहता है। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Hello World

लंबोदर कार्य

लैम्ब्डा प्रोग्रामिंग में अनाम कार्यों को संदर्भित करता है। अनाम कार्यों का प्रतिनिधित्व करने के लिए लैम्ब्डा फ़ंक्शन एक संक्षिप्त तंत्र हैं। इन कार्यों को भी कहा जाता हैArrow functions

लैम्ब्डा फंक्शन - एनाटॉमी

लाम्बा समारोह के 3 भाग हैं -

  • Parameters - एक फ़ंक्शन में वैकल्पिक रूप से पैरामीटर हो सकते हैं।

  • fat arrow notation/lambda notation (=>): इसे ऑपरेटर के रूप में भी जाना जाता है।

  • Statements - फ़ंक्शन के इंस्ट्रक्शन सेट का प्रतिनिधित्व करता है।

Tip - सम्मेलन द्वारा, एक कॉम्पैक्ट और सटीक फ़ंक्शन घोषणा के लिए एकल अक्षर पैरामीटर के उपयोग को प्रोत्साहित किया जाता है।

लैम्ब्डा एक्सप्रेशन

यह एक अनाम फ़ंक्शन एक्सप्रेशन है जो कोड की एकल पंक्ति को इंगित करता है। निम्नलिखित के लिए सिंटैक्स है।

([param1, parma2,…param n] )=>statement;

Example − Lambda Expression

var foo = (x)=>10+x 
console.log(foo(10))

उदाहरण एक लंबोदर अभिव्यक्ति फ़ंक्शन घोषित करता है। फ़ंक्शन 10 का योग लौटाता है और तर्क पास हो जाता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

20

लाम्बा स्टेटमेंट

यह एक अनाम फ़ंक्शन घोषणा है जो कोड के एक ब्लॉक को इंगित करता है। यह सिंटैक्स तब उपयोग किया जाता है जब फ़ंक्शन बॉडी कई लाइनों को फैलाता है। निम्नलिखित उसी का वाक्य विन्यास है।

( [param1, parma2,…param n] )=> {       
   //code block 
}

Example − Lambda Statement

var msg = ()=> { 
   console.log("function invoked") 
} 
msg()

फ़ंक्शन का संदर्भ लौटाया जाता है और चर संदेश में संग्रहीत किया जाता है। निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

function  invoked

संश्लिष्ट रूपांतर

एकल पैरामीटर के लिए वैकल्पिक कोष्ठक।

var msg = x=> { 
   console.log(x) 
} 
msg(10)

एक बयान के लिए वैकल्पिक ब्रेसिज़। कोई पैरामीटर के लिए खाली कोष्ठक।

var disp = ()=>console.log("Hello World") 
disp();

समारोह अभिव्यक्ति और समारोह घोषणा

फंक्शन एक्सप्रेशन और फंक्शन डिक्लेरेशन पर्यायवाची नहीं हैं। एक फ़ंक्शन अभिव्यक्ति के विपरीत, एक फ़ंक्शन घोषणा फ़ंक्शन नाम से बाध्य होती है।

दोनों के बीच बुनियादी अंतर यह है कि, कार्य घोषणाएं उनके निष्पादन से पहले पार्स की जाती हैं। दूसरी ओर, फ़ंक्शन अभिव्यक्तियों को केवल तब ही पार्स किया जाता है जब स्क्रिप्ट इंजन एक निष्पादन के दौरान इसका सामना करता है।

जब जावास्क्रिप्ट पार्सर मुख्य कोड प्रवाह में एक फ़ंक्शन देखता है, तो यह फ़ंक्शन घोषणा को मानता है। जब कोई फ़ंक्शन किसी कथन के भाग के रूप में आता है, तो यह एक फ़ंक्शन एक्सप्रेशन है।

फहराने की क्रिया

चरों की तरह, फ़ंक्शंस भी फहराए जा सकते हैं। चरों के विपरीत, फंक्शन की घोषणाएं जब फहराई जाती हैं, तो फ़ंक्शन के नाम को फहराने के बजाय फ़ंक्शन की परिभाषा को बढ़ाता है।

निम्नलिखित कोड स्निपेट, जावास्क्रिप्ट में फहराए जाने वाले फ़ंक्शन को दिखाता है।

hoist_function();  
function hoist_function() { 
   console.log("foo"); 
}

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

foo

हालाँकि, फ़ंक्शन अभिव्यक्तियों को फहराया नहीं जा सकता। निम्न कोड स्निपेट समान दिखाता है।

hoist_function(); // TypeError: hoist_function() is not a function  
var hoist_function() = function() { 
   console.log("bar"); 
};

तुरंत फंक्शन अभिव्यक्ति

ब्लॉकों के भीतर परिवर्तनशील उत्थापन से बचने के लिए तुरंत इनवाइटेड फंक्शन एक्सप्रेशन (IIFE) का उपयोग किया जा सकता है। यह फ़ंक्शन के भीतर परिभाषित चर के लिए गोपनीयता बनाए रखते हुए विधियों तक सार्वजनिक पहुंच की अनुमति देता है। इस पैटर्न को एक आत्म-निष्पादित अनाम फ़ंक्शन के रूप में कहा जाता है। निम्नलिखित दो उदाहरण इस अवधारणा को बेहतर ढंग से समझाते हैं।

उदाहरण 1: IIFE

var main = function() { 
   var loop = function() { 
      for(var x = 0;x<5;x++) {
         console.log(x); 
      } 
   }(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

उदाहरण 2: IIFE

var main = function() { 
   (function() { 
      for(var x = 0;x<5;x++) { 
         console.log(x); 
      } 
   })(); 
   console.log("x can not be accessed outside the block scope x value is :"+x); 
} 
main();

दोनों उदाहरण निम्नलिखित आउटपुट प्रस्तुत करेंगे।

0 
1 
2 
3 
4 
Uncaught ReferenceError: x is not define

जेनरेटर के कार्य

जब एक सामान्य फ़ंक्शन का आह्वान किया जाता है, तो नियंत्रण उस फ़ंक्शन के साथ रहता है जिसे तब तक बुलाया जाता है जब तक वह वापस नहीं लौटता। ES6 में जनरेटर के साथ, कॉलर फ़ंक्शन अब किसी फ़ंक्शन के निष्पादन को नियंत्रित कर सकता है। एक जनरेटर एक नियमित कार्य की तरह है सिवाय इसके कि -

  • फ़ंक्शन किसी भी बिंदु पर कॉलर को वापस नियंत्रित कर सकता है।

  • जब आप एक जनरेटर को बुलाते हैं, तो यह तुरंत नहीं चलता है। इसके बजाय, आप एक पुनरावृत्तिकर्ता प्राप्त करते हैं। फ़ंक्शन चलता है जैसे ही आप इट्रेटर की अगली विधि कहते हैं।

जेनरेटर को तारांकन चिह्न के साथ फ़ंक्शन कीवर्ड को दबाकर निरूपित किया जाता है; अन्यथा, उनका सिंटैक्स नियमित कार्यों के समान है।

निम्न उदाहरण उसी का चित्रण करता है।

"use strict" 
function* rainbow() { 
   // the asterisk marks this as a generator 
   yield 'red'; 
   yield 'orange'; 
   yield 'yellow'; 
   yield 'green'; 
   yield 'blue'; 
   yield 'indigo'; 
   yield 'violet'; 
} 
for(let color of rainbow()) { 
   console.log(color); 
}

जनरेटर कॉल करने वाले और बुलाया फ़ंक्शन के बीच दो-तरफ़ा संचार सक्षम करते हैं। यह का उपयोग करके पूरा किया हैyield कीवर्ड।

निम्नलिखित उदाहरण पर विचार करें -

function* ask() { 
   const name = yield "What is your name?"; 
   const sport = yield "What is your favorite sport?"; 
   return `${name}'s favorite sport is ${sport}`; 
}  
const it = ask(); 
console.log(it.next()); 
console.log(it.next('Ethan'));  
console.log(it.next('Cricket'));

जनरेटर फ़ंक्शन की अनुक्रम निम्नानुसार है -

  • बताए गए तरीके से शुरू किया गया जनरेटर; पुनरावृतिकर्ता लौटाया जाता है

  • It.next () पैदावार "आपका नाम क्या है"। जनरेटर को रोक दिया जाता है। यह उपज कीवर्ड द्वारा किया जाता है।

  • कॉल इट.नेक्स्ट ("एथन"), एथन को वैरिएबल नाम के लिए मान देता है और "आपका स्पोर्ट क्या है?" फिर से जनरेटर को रोक दिया जाता है।

  • कॉल it.next ("क्रिकेट") चर खेल के लिए मूल्य क्रिकेट प्रदान करता है और बाद के विवरण को निष्पादित करता है।

इसलिए, उपरोक्त कोड का उत्पादन होगा -

{ 
   value: 'What is your name?', done: false 
} 
{ 
   value: 'What is your favorite sport?', done: false 
} 
{ 
   value: 'Ethan\'s favorite sport is Cricket', done: true 
}

Note - तीर फ़ंक्शन का उपयोग करके जनरेटर कार्यों का प्रतिनिधित्व नहीं किया जा सकता है।

एरो फ़ंक्शंस

ES में पेश किए गए एरो फ़ंक्शंस जावास्क्रिप्ट में फ़ंक्शंस को संक्षिप्त तरीके से लिखने में मदद करते हैं। आइए अब उसी के बारे में विस्तार से जानें।

ES5 और बेनामी फ़ंक्शन

जावास्क्रिप्ट का भारी उपयोग करता है anonymous functions। एक अनाम फ़ंक्शन एक फ़ंक्शन होता है जिसमें कोई नाम जुड़ा नहीं होता है। बेनामी कार्यों के दौरान उपयोग किया जाता हैfunction callback। निम्न उदाहरण ईएस 5 में एक अनाम फ़ंक्शन के उपयोग को दिखाता है -

<script>
   setTimeout(function(){
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

उपरोक्त उदाहरण पूर्वनिर्धारित के पैरामीटर के रूप में एक अनाम फ़ंक्शन को पास करता है setTimeout() function। सेटटाइमआउट () फ़ंक्शन 1 सेकंड के बाद अनाम फ़ंक्शन को कॉलबैक करेगा।

निम्नलिखित उत्पादन 1 सेकंड के बाद दिखाया गया है -

Learning at TutorialsPoint is fun!!

एरो फंक्शन सिंटेक्स

ES6 की अवधारणा का परिचय देता है arrow function के उपयोग को आसान बनाने के लिए anonymous function। एक एरो फंक्शन के 3 भाग हैं जो इस प्रकार हैं -

  • Parameters - एक तीर फ़ंक्शन वैकल्पिक रूप से पैरामीटर हो सकता है

  • The fat arrow notation (=>) - इसे ऑपरेटर के रूप में भी जाना जाता है

  • Statements - फ़ंक्शन के इंस्ट्रक्शन सेट का प्रतिनिधित्व करता है

Tip - सम्मेलन द्वारा, कॉम्पैक्ट और सटीक एरो फ़ंक्शन घोषणा के लिए एकल अक्षर पैरामीटर के उपयोग को प्रोत्साहित किया जाता है।

वाक्य - विन्यास

//Arrow function that points to a single line of code
()=>some_expression

या

//Arrow function that points to a block of code
()=> { //some statements }`

या

//Arrow function with parameters
(param1,param2)=>{//some statement}

उदाहरण: ES6 में एरो फंक्शन

निम्न उदाहरण दो फ़ंक्शन अभिव्यक्तियों को परिभाषित करता है add तथा isEven एरो फंक्शन का उपयोग करना

<script>
   const add = (n1,n2) => n1+n2
   console.log(add(10,20))

   const isEven = (n1) => {
      if(n1%2 == 0)
         return true;
      else
         return false;
   }
   console.log(isEven(10))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

30
true

Array.prototyp.map () और एरो फंक्शन

निम्नलिखित उदाहरण में, एक तीर फ़ंक्शन को पैरामीटर के रूप में पास किया जाता है Array.prototype.map() function.नक्शा () फ़ंक्शन सरणी में प्रत्येक तत्व के लिए तीर फ़ंक्शन को निष्पादित करता है। इस मामले में तीर फ़ंक्शन, सरणी और उसके सूचकांक में प्रत्येक तत्व को प्रदर्शित करता है।

<script>
   const names = ['TutorialsPoint','Mohtashim','Bhargavi','Raja']
   names.map((element,index)=> {
      console.log('inside arrow function')
      console.log('index is '+index+' element value is :'+element)
   })
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

inside arrow function
index is 0 element value is :TutorialsPoint
inside arrow function
index is 1 element value is :Mohtashim
inside arrow function
index is 2 element value is :Bhargavi
inside arrow function
index is 3 element value is :Raja

उदाहरण: window.setTimeout () और एरो फंक्शन

निम्न उदाहरण पूर्वनिर्धारित के पैरामीटर के रूप में एक तीर फ़ंक्शन पास करता है setTimeout() functionsetTimeout() फ़ंक्शन 1 सेकंड के बाद तीर फ़ंक्शन को कॉलबैक करेगा।

<script>
   setTimeout(()=>{
      console.log('Learning at TutorialsPoint is fun!!')
   },1000)
</script>

निम्नलिखित उत्पादन 1 सेकंड के बाद दिखाया गया है -

Learning at TutorialsPoint is fun!!

एरो फ़ंक्शन और "यह"

यदि हम उपयोग करते हैं तो एक एरो फंक्शन के अंदर this pointer, यह घेरने वाले शाब्दिक दायरे की ओर इशारा करेगा। इसका मतलब है कि तीर फ़ंक्शंस एक नया नहीं बनाते हैंthis pointerउदाहरण के लिए जब भी इसे लागू किया जाता है। एरो फ़ंक्शंस इसके संलग्न दायरे का उपयोग करता है। इसे समझने के लिए, आइए एक उदाहरण देखें।

<script>
   //constructor function
   function Student(rollno,firstName,lastName) {
      this.rollno = rollno;
      this.firstName = firstName;
      this.lastName = lastName;
      this.fullNameUsingAnonymous = function(){
         setTimeout(function(){
            //creates a new instance of this ,hides outer scope of this
            console.log(this.firstName+ " "+this.lastName)
         },2000)
      }
      this.fullNameUsingArrow = function(){
         setTimeout(()=>{
            //uses this instance of outer scope
            console.log(this.firstName+ " "+this.lastName)
         },3000)
      }
   }
   const s1 = new Student(101,'Mohammad','Mohtashim')
   s1.fullNameUsingAnonymous();
   s1.fullNameUsingArrow();
</script>

जब एक अनाम फ़ंक्शन का उपयोग किया जाता है setTimeout()2000 मिलीसेकंड के बाद फ़ंक्शन को लागू किया जाता है। का एक नया उदाहरण“this”बनाया गया है और यह छात्र फ़ंक्शन के उदाहरण को छाया देता है। तो, का मूल्यthis.firstName तथा this.lastName होगा undefined। फ़ंक्शन लेक्सिकल स्कोप या वर्तमान निष्पादन के संदर्भ का उपयोग नहीं करता है। A का उपयोग करके इस समस्या को हल किया जा सकता हैarrow function

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

undefined undefined
Mohammad Mohtashim

जावास्क्रिप्ट आपके पृष्ठों में अन्तरक्रियाशीलता जोड़ने के लिए है। जावास्क्रिप्ट घटनाओं का उपयोग करके एक तंत्र का उपयोग करता है।Events दस्तावेज़ ऑब्जेक्ट मॉडल (DOM) स्तर 3 का एक हिस्सा हैं और प्रत्येक HTML तत्व में जावास्क्रिप्ट कोड को ट्रिगर करने वाली घटनाओं का एक समूह होता है।

एक घटना सॉफ्टवेयर द्वारा मान्यता प्राप्त एक क्रिया या घटना है। यह एक उपयोगकर्ता या सिस्टम द्वारा ट्रिगर किया जा सकता है। घटनाओं के कुछ सामान्य उदाहरणों में एक बटन पर क्लिक करने वाला उपयोगकर्ता, वेब पेज लोड करना, हाइपरलिंक पर क्लिक करना आदि शामिल हैं। निम्नलिखित कुछ सामान्य HTML ईवेंट हैं।

इवेंट हैंडलर

एक घटना की घटना पर, आवेदन संबंधित कार्यों के एक सेट को निष्पादित करता है। इस उद्देश्य को प्राप्त करने वाले कोड को ब्लॉक कहा जाता हैeventhandler। प्रत्येक HTML तत्व में इसके साथ जुड़े घटनाओं का एक समूह होता है। हम यह परिभाषित कर सकते हैं कि ईवेंट हैंडलर का उपयोग करके घटनाओं को जावास्क्रिप्ट में कैसे संसाधित किया जाएगा।

onclick Event Type

यह सबसे अधिक उपयोग किया जाने वाला ईवेंट प्रकार है जो तब होता है जब कोई उपयोगकर्ता अपने माउस के बाएं बटन पर क्लिक करता है। आप इस घटना के प्रकार के खिलाफ अपनी मान्यता, चेतावनी आदि रख सकते हैं।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript">  
         function sayHello() {  
            document.write ("Hello World")  
         }   
      </script> 
   </head> 
   
   <body> 
      <p> Click the following button and see result</p> 
      <input type = "button" onclick = "sayHello()" value = "Say Hello" /> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

OnubmitEvent प्रकार

onsubmitएक घटना है जो तब होती है जब आप एक फ़ॉर्म सबमिट करने का प्रयास करते हैं। आप इस ईवेंट प्रकार के विरुद्ध अपना फ़ॉर्म सत्यापन डाल सकते हैं।

निम्नलिखित उदाहरण दिखाता है कि कैसे उपयोग किया जाए onsubmit। यहां हम वेबसर्वर को एक फॉर्म डेटा सबमिट करने से पहले एक मान्य () फ़ंक्शन को बुला रहे हैं। यदि मान्य () फ़ंक्शन सही है, तो फ़ॉर्म सबमिट किया जाएगा, अन्यथा यह डेटा सबमिट नहीं करेगा।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript">  
         function validation() {  
            all validation goes here  
            .........  
            return either true or false  
         }   
      </script> 
   </head> 
   
   <body> 
      <form method = "POST" action = "t.cgi" onsubmit = "return validate()"> 
         .......  
         <input type = "submit" value = "Submit" /> 
      </form> 
   </body> 
</html>

onmouseover और onmouseout

ये दो ईवेंट प्रकार आपको छवियों के साथ या पाठ के साथ भी अच्छा प्रभाव बनाने में मदद करेंगे। onmouseover इवेंट ट्रिगर जब आप अपने माउस को किसी भी तत्व और पर लाते हैं onmouseout जब आप अपने माउस को उस तत्व से बाहर निकालते हैं तो ट्रिगर होता है।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function over() {  
            document.write ("Mouse Over");  
         }  
         function out() {  
            document.write ("Mouse Out");  
         }  
      </script> 
   </head> 

   <body> 
      <p>Bring your mouse inside the division to see the result:</p> 
      <div onmouseover = "over()" onmouseout = "out()"> 
         <h2> This is inside the division </h2> 
      </div> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

HTML 5 मानक ईवेंट

मानक HTML 5 ईवेंट्स आपके संदर्भ के लिए निम्न तालिका में सूचीबद्ध हैं। स्क्रिप्ट उस घटना के खिलाफ निष्पादित होने के लिए एक जावास्क्रिप्ट फ़ंक्शन को इंगित करती है।

गुण मूल्य विवरण
ऑफ़लाइन लिपि दस्तावेज़ ऑफ़लाइन होने पर ट्रिगर
onabort लिपि एक गर्भपात की घटना पर ट्रिगर
onafterprint लिपि दस्तावेज़ मुद्रित होने के बाद ट्रिगर
onbeforeonload लिपि दस्तावेज़ लोड होने से पहले ट्रिगर
onbeforeprint लिपि दस्तावेज़ मुद्रित होने से पहले ट्रिगर
धब्बे पर लिपि जब विंडो फ़ोकस करता है तो ट्रिगर
oncanplay लिपि ट्रिगर जब मीडिया खेलना शुरू कर सकता है, लेकिन बफरिंग के लिए रुकना पड़ सकता है
oncanplaythrough लिपि ट्रिगर जब मीडिया बफ़रिंग के लिए रोक के बिना, अंत तक खेला जा सकता है
परिवर्तन पर लिपि जब कोई तत्व बदलता है तो ट्रिगर
क्लिक पर लिपि एक माउस क्लिक पर ट्रिगर
oncontextmenu लिपि जब संदर्भ मेनू ट्रिगर होता है तो ट्रिगर
ondblclick लिपि माउस पर ट्रिगर डबल-क्लिक करें
ondrag लिपि किसी तत्व को खींचने पर ट्रिगर
ondragend लिपि एक ड्रैग ऑपरेशन के अंत में ट्रिगर
OnDragEnter लिपि जब कोई तत्व किसी वैध ड्रॉप लक्ष्य पर खींचा जाता है तो ट्रिगर
ondragleave लिपि जब कोई तत्व एक वैध ड्रॉप लक्ष्य छोड़ता है तो ट्रिगर
ondragover लिपि जब किसी तत्व को वैध ड्रॉप लक्ष्य पर खींचा जा रहा हो तो ट्रिगर
ondragstart लिपि एक ड्रैग ऑपरेशन की शुरुआत में ट्रिगर
ondrop लिपि जब घसीटा तत्व गिराया जा रहा है तो ट्रिगर
ondurationchange लिपि मीडिया की लंबाई बदलने पर ट्रिगर
onemptied लिपि ट्रिगर जब एक मीडिया संसाधन तत्व अचानक खाली हो जाता है
onended लिपि ट्रिगर जब मीडिया अंत तक पहुँच गया है
onerror लिपि त्रुटि होने पर ट्रिगर
पर ध्यान केंद्रित लिपि विंडो फोकस होने पर ट्रिगर
onformchange लिपि जब कोई रूप बदलता है तो ट्रिगर
onforminput लिपि जब किसी प्रपत्र को उपयोगकर्ता इनपुट मिलता है तो ट्रिगर
onhaschange लिपि जब दस्तावेज़ बदल गया है तो ट्रिगर
oninput लिपि जब किसी तत्व को उपयोगकर्ता इनपुट मिलता है तो ट्रिगर
oninvalid लिपि किसी तत्व के अमान्य होने पर ट्रिगर
onkeydown लिपि ट्रिगर जब एक कुंजी दबाया जाता है
onkeypress लिपि ट्रिगर जब एक कुंजी दबाया और जारी किया जाता है
onkeyup लिपि एक कुंजी जारी होने पर ट्रिगर
गोली भरना लिपि दस्तावेज़ लोड होने पर ट्रिगर
onloadeddata लिपि मीडिया डेटा लोड होने पर ट्रिगर
onloadedmetadata लिपि एक मीडिया तत्व की अवधि और अन्य मीडिया डेटा लोड होने पर ट्रिगर
onloadstart लिपि ट्रिगर जब ब्राउज़र मीडिया डेटा लोड करना शुरू करता है
onmessage लिपि संदेश ट्रिगर होने पर ट्रिगर
onmousedown लिपि ट्रिगर जब एक माउस बटन दबाया जाता है
onmousemove लिपि जब माउस पॉइंटर चलता है तो ट्रिगर
onmouseout लिपि ट्रिगर जब माउस पॉइंटर एक तत्व से बाहर निकलता है
मूषक के ऊपर से लिपि जब माउस पॉइंटर किसी तत्व पर चलता है तो ट्रिगर
onmouseup लिपि जब माउस बटन छोड़ा जाता है तो ट्रिगर
onmousewheel लिपि ट्रिगर जब माउस व्हील घुमाया जा रहा है
onoffline लिपि दस्तावेज़ ऑफ़लाइन होने पर ट्रिगर
ononline लिपि दस्तावेज़ ऑनलाइन आने पर ट्रिगर
onpagehide लिपि जब खिड़की छिपी हो तो ट्रिगर
onpageshow लिपि विंडो दिखाई देने पर ट्रिगर
onpause लिपि मीडिया डेटा रोक दिए जाने पर ट्रिगर
onplay लिपि ट्रिगर जब मीडिया डेटा खेलना शुरू कर रहा है
onplaying लिपि ट्रिगर जब मीडिया डेटा खेलना शुरू हो गया है
onpopstate लिपि जब विंडो का इतिहास बदलता है तो ट्रिगर
प्रगति पर लिपि ट्रिगर जब ब्राउज़र मीडिया डेटा प्राप्त कर रहा है
onratechange लिपि ट्रिगर जब मीडिया डेटा की प्लेइंग रेट बदल गई हो
onreadystatechange लिपि जब तैयार स्थिति बदल जाती है तो ट्रिगर
onredo लिपि जब दस्तावेज़ एक नया प्रदर्शन करता है तो ट्रिगर
onresize लिपि विंडो के आकार बदलने पर ट्रिगर
Onscroll लिपि जब किसी तत्व के स्क्रॉलबार को स्क्रॉल किया जा रहा हो तो ट्रिगर
onseeked लिपि ट्रिगर जब मीडिया तत्व की मांग विशेषता अब सच नहीं है, और मांग समाप्त हो गई है
onseeking लिपि ट्रिगर जब एक मीडिया तत्व की मांग विशेषता सच है, और मांग शुरू हो गई है
onselect लिपि जब किसी तत्व का चयन किया जाता है तो ट्रिगर
onstalled लिपि मीडिया डेटा प्राप्त करने में त्रुटि होने पर ट्रिगर
onstorage लिपि दस्तावेज़ लोड होने पर ट्रिगर
ऑनसबमिट लिपि प्रपत्र सबमिट करने पर ट्रिगर
onsuspend लिपि ट्रिगर जब ब्राउज़र मीडिया डेटा प्राप्त कर रहा है, लेकिन पूरी मीडिया फ़ाइल को लाने से पहले रोक दिया गया था
ontimeupdate लिपि ट्रिगर जब मीडिया अपनी प्लेइंग पोजीशन बदलता है
onundo लिपि जब कोई दस्तावेज़ पूर्ववत करता है तो ट्रिगर
ऑनअनलोड लिपि उपयोगकर्ता द्वारा दस्तावेज़ छोड़ने पर ट्रिगर
onvolumechange लिपि ट्रिगर जब मीडिया वॉल्यूम बदलता है, तब भी जब वॉल्यूम "म्यूट" पर सेट होता है
onwaiting लिपि ट्रिगर जब मीडिया ने खेलना बंद कर दिया है, लेकिन फिर से शुरू होने की उम्मीद है

वेब ब्राउजर और सर्वर संचार के लिए HTTP प्रोटोकॉल का उपयोग करते हैं। HTTP स्टेटलेस प्रोटोकॉल है, अर्थात, यह क्लाइंट द्वारा किए गए कई अनुरोधों पर ग्राहक के डेटा को बनाए नहीं रखता है। क्लाइंट और सर्वर के बीच यह पूर्ण अनुरोध-प्रतिक्रिया चक्र ए के रूप में परिभाषित किया गया हैsession। उपयोगकर्ता के सत्र से संबंधित डेटा को संग्रहीत करने के लिए कुकीज़ ब्राउज़र द्वारा उपयोग किया जाने वाला डिफ़ॉल्ट तंत्र है।

यह काम किस प्रकार करता है?

आपका सर्वर कुकी के रूप में विज़िटर के ब्राउज़र में कुछ डेटा भेजता है। ब्राउज़र कुकी को स्वीकार कर सकता है। यदि ऐसा होता है, तो इसे विज़िटर की हार्ड ड्राइव पर एक सादे टेक्स्ट रिकॉर्ड के रूप में संग्रहीत किया जाता है। अब, जब आगंतुक आपकी साइट पर किसी अन्य पेज पर आता है, तो ब्राउज़र उसी कुकी को रिट्रीवल के लिए सर्वर पर भेजता है। एक बार पुनर्प्राप्त होने के बाद, आपका सर्वर जानता है / याद रखता है कि पहले क्या संग्रहीत किया गया था।

कुकीज़ 5 चर-लंबाई क्षेत्रों के सादे पाठ डेटा रिकॉर्ड हैं।

  • Expires- कुकी की तारीख समाप्त हो जाएगी। यदि यह रिक्त है, तो आगंतुक के ब्राउज़र को छोड़ने पर कुकी समाप्त हो जाएगी।

  • Domain - आपकी साइट का डोमेन नाम।

  • Path- निर्देशिका या वेब पेज के लिए पथ जो कुकी सेट करता है। यह रिक्त हो सकता है, यदि आप कुकी को किसी भी निर्देशिका या पृष्ठ से पुनर्प्राप्त करना चाहते हैं।

  • Secure- यदि इस फ़ील्ड में "सुरक्षित" शब्द है, तो कुकी को केवल एक सुरक्षित सर्वर के साथ पुनर्प्राप्त किया जा सकता है। यदि यह फ़ील्ड रिक्त है, तो ऐसा कोई प्रतिबंध मौजूद नहीं है।

  • Name = Value - कुकीज़ कुंजी-मूल्य जोड़े के रूप में सेट और पुनर्प्राप्त की जाती हैं।

कुकीज़ मूल रूप से CGI प्रोग्रामिंग के लिए डिज़ाइन की गई थीं। कुकी में मौजूद डेटा स्वचालित रूप से वेब ब्राउज़र और वेब सर्वर के बीच संचारित होता है, इसलिए सर्वर पर CGI स्क्रिप्ट कुकी मानों को पढ़ और लिख सकता है जो क्लाइंट साइड पर संग्रहीत होते हैं।

दस्तावेज़ दस्तावेज़ की कुकी संपत्ति का उपयोग करके जावास्क्रिप्ट भी कुकीज़ में हेरफेर कर सकती है। जावास्क्रिप्ट वर्तमान वेब पेज पर लागू होने वाली कुकीज़ को पढ़, बना, संशोधित और हटा सकता है।

स्टोरिंग कुकीज़

कुकी बनाने का सबसे सरल तरीका है, स्ट्रिंग मान निर्दिष्ट करना document.cookie ऑब्जेक्ट, जो इस तरह दिखता है।

"document.cookie = "key1 = value1; key2 = value2; expires = date";

यहाँ, 'एक्सपायर' विशेषता वैकल्पिक है। यदि आप एक मान्य दिनांक या समय के साथ यह विशेषता प्रदान करते हैं, तो कुकी दी गई तिथि या समय पर समाप्त हो जाएगी और उसके बाद, कुकीज़ का मूल्य सुलभ नहीं होगा।

Note- कुकी मानों में अर्धविराम, अल्पविराम या व्हॉट्सएप शामिल नहीं हो सकते हैं। इस कारण से, आप जावास्क्रिप्ट का उपयोग करना चाह सकते हैंescape()कुकी में संग्रहीत करने से पहले मान को एन्कोड करने के लिए फ़ंक्शन। यदि आप ऐसा करते हैं, तो आपको संबंधित का भी उपयोग करना होगाunescape() जब आप कुकी मान पढ़ते हैं तो कार्य करते हैं।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript">  
         function WriteCookie() {  
            if( document.myform.customer.value == "" ){  
               alert ("Enter some value!");  
               return;  
            }  
            cookievalue =  escape(document.myform.customer.value) + ";";  
            document.cookie = "name = " + cookievalue;  
            document.write ("Setting Cookies : " + "name = " + cookievalue );  
         }  
      </script> 
   </head> 
      
   <body> 
      <form name = "myform" action = ""> 
         Enter name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set" onclick = "WriteCookie();"/> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

अब आपकी मशीन में एक कुकी नाम है। आप कॉमा द्वारा अलग किए गए कई कुंजी = मान जोड़े का उपयोग करके कई कुकीज़ सेट कर सकते हैं।

कुकीज़ पढ़ना

कुकी को पढ़ना उतना ही सरल है, जितना कि लिखना document.cookieवस्तु कुकी है। इसलिए जब भी आप कुकी एक्सेस करना चाहते हैं, तो आप इस स्ट्रिंग का उपयोग कर सकते हैं। document.cookie स्ट्रिंग नाम की एक सूची रखेगा = मूल्य जोड़े अर्धविरामों द्वारा अलग किए जाएंगे, जहां नाम कुकी का नाम है और मूल्य इसका स्ट्रिंग मान है।

आप तार का उपयोग कर सकते हैं ' split() निम्न उदाहरण में दिखाए गए अनुसार स्ट्रिंग को कुंजी और मानों में तोड़ने के लिए।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function ReadCookie() {  
            var allcookies  =  document.cookie;  
            document.write ("All Cookies : " + allcookies ); 
         } 
         // Get all the cookies pairs in an array  
         cookiearray = allcookies.split(';');  
         
         // Now take key value pair out of this array  
         for(var i = 0; i<cookiearray.length; i++) {  
            name  =  cookiearray[i].split('=')[0];  
            value = cookiearray[i].split('=')[1];  
            document.write ("Key is : " + name + " and Value is : " + value); 
         }  
      </script> 
   </head> 

   <body> 
      <form name = "myform" action = ""> 
         <p> click the following button and see the result:</p> 
         <input type = "button" value = "Get Cookie" onclick = "ReadCookie()"/> 
      </form> 
   </body> 
</html>

Note - यहाँ, लंबाई ऐरे वर्ग की एक विधि है जो एक सरणी की लंबाई लौटाती है।

आपकी मशीन पर पहले से ही कुछ अन्य कुकीज हो सकती हैं। उपरोक्त कोड आपके मशीन पर सेट सभी कुकीज़ को प्रदर्शित करेगा।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

कुकीज़ समाप्ति तिथि निर्धारित करना

आप समाप्ति तिथि सेट करके और कुकी के भीतर की समाप्ति की तारीख को सहेजकर वर्तमान ब्राउज़र सत्र से परे कुकी के जीवन का विस्तार कर सकते हैं। यह एक तिथि और समय के लिए 'समय सीमा समाप्त' विशेषता सेट करके किया जा सकता है। निम्न उदाहरण दिखाता है कि कुकी की समाप्ति तिथि को 1 महीने तक कैसे बढ़ाया जाए।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function WriteCookie() {  
            var now = new Date();  
            now.setMonth( now.getMonth() + 1 );  
            cookievalue = escape(document.myform.customer.value) + ";"  
            document.cookie = "name = " + cookievalue;  
            document.cookie = "expires = " + now.toUTCString() + ";"  
            document.write ("Setting Cookies : " + "name = " + cookievalue );  
         } 
      </script> 
   </head> 

   <body> 
      <form name = "formname" action = ""> 
         Enter Cookie Name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

एक कुकी को हटाना

कभी-कभी आप एक कुकी को हटाना चाहेंगे, ताकि बाद में कुकी वापस पढ़ने के प्रयास से कुछ भी न हो। ऐसा करने के लिए, आपको बस एक समय में समाप्ति की तारीख निर्धारित करने की आवश्यकता है। निम्न उदाहरण दिखाता है कि वर्तमान तिथि से एक महीने पहले इसकी समाप्ति तिथि निर्धारित करके कुकी को कैसे हटाया जाए।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function WriteCookie() {  
            var now = new Date();  
            now.setMonth( now.getMonth() - 1 );  
            cookievalue = escape(document.myform.customer.value) + ";" 
            document.cookie = "name=" + cookievalue;  
            document.cookie = "expires = " + now.toUTCString() + ";"  
            document.write("Setting Cookies : " + "name = " + cookievalue );  
         }  
      </script> 
   </head> 

   <body> 
      <form name = "formname" action = ""> 
         Enter Cookie Name: <input type = "text" name = "customer"/> 
         <input type = "button" value = "Set Cookie" onclick = "WriteCookie()"/> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Redirectदोनों उपयोगकर्ताओं और खोज इंजनों को मूल URL के लिए एक अलग URL पर भेजने का एक तरीका है। पृष्ठ पुनर्निर्देशन किसी वेब पेज को दूसरे वेब पेज पर स्वचालित रूप से रीडायरेक्ट करने का एक तरीका है। पुनर्निर्देशित पृष्ठ अक्सर एक ही वेबसाइट पर होता है, या यह किसी भिन्न वेबसाइट या वेब सर्वर पर हो सकता है।

जावास्क्रिप्ट पृष्ठ पुनर्निर्देशन

window.location and window.location.href

जावास्क्रिप्ट में, आप वेब पेज को एक दूसरे पर पुनर्निर्देशित करने के लिए कई तरीकों का उपयोग कर सकते हैं। लगभग सभी विधियां संबंधित हैंwindow.locationऑब्जेक्ट, जो विंडो ऑब्जेक्ट की एक संपत्ति है। इसका उपयोग वर्तमान URL पता (वेब ​​पता) प्राप्त करने और ब्राउज़र को एक नए पृष्ठ पर पुनर्निर्देशित करने के लिए किया जा सकता है। व्यवहार के संदर्भ में दोनों ही उपयोग समान हैं।window.locationकोई वस्तु लौटाता है। अगर.href सेट नहीं है, window.location पैरामीटर बदलने के लिए चूक .href

उदाहरण

<!DOCTYPE html> 
<html> 
   <head> 
      <script> 
         function newLocation() { 
            window.location = "http://www.xyz.com"; 
         } 
      </script> 
   </head> 

   <body> 
      <input type = "button" value = "Go to new location" onclick = "newLocation()"> 
   </body> 
</html>

location.replace()

अन्य सबसे अधिक उपयोग की जाने वाली विधि है replace()window.location ऑब्जेक्ट की विधि, यह वर्तमान दस्तावेज़ को एक नए के साथ बदल देगा। प्रतिस्थापित () विधि में, आप प्रतिस्थापित करने के लिए एक नया URL पारित कर सकते हैं () विधि और यह HTTP रीडायरेक्ट करेगा।

निम्नलिखित के लिए सिंटैक्स है।

window.location.replace("http://www.abc.com

location.assign()

Location.assign () विधि ब्राउज़र विंडो में एक नया दस्तावेज़ लोड करता है।

निम्नलिखित के लिए सिंटैक्स है।

window.location.assign("http://www.abc.org");

assign() vs. replace()

असाइन () और प्रतिस्थापित () विधि के बीच का अंतर यह है कि location.replace () विधि दस्तावेज़ इतिहास से वर्तमान URL को हटा देती है, इसलिए यह मूल दस्तावेज़ पर वापस नेविगेट करने में असमर्थ है। आप इस मामले में ब्राउज़र "बैक" बटन का उपयोग नहीं कर सकते। यदि आप इस स्थिति से बचना चाहते हैं, तो आपको location.assign () विधि का उपयोग करना चाहिए, क्योंकि यह ब्राउज़र में एक नया दस्तावेज़ लोड करता है।

location.reload()

Location.reload () विधि ब्राउज़र विंडो में वर्तमान दस्तावेज़ को पुनः लोड करता है।

निम्नलिखित के लिए सिंटैक्स है।

window.location.reload("http://www.yahoo.com");

window.navigate()

Window.navigate () विधि window.location.href प्रॉपर्टी के नए मूल्य को निर्दिष्ट करने के समान है। क्योंकि यह केवल एमएस इंटरनेट एक्सप्लोरर में उपलब्ध है, इसलिए आपको क्रॉस-ब्राउज़र विकास में इसका उपयोग करने से बचना चाहिए।

निम्नलिखित के लिए सिंटैक्स है।

window.navigate("http://www.abc.com");

पुनर्निर्देशन और खोज इंजन अनुकूलन

यदि आप अपने URL अग्रेषण के बारे में खोज इंजन (SEO) को सूचित करना चाहते हैं, तो आपको अपनी वेबसाइट के हेड भाग में rel = "canonical" मेटा टैग जोड़ना चाहिए क्योंकि खोज इंजन रीडायरेक्ट की जांच करने के लिए जावास्क्रिप्ट का विश्लेषण नहीं करते हैं।

निम्नलिखित के लिए सिंटैक्स है।

<link rel = "canonical" href = "http://abc.com/" />

जावास्क्रिप्ट तीन महत्वपूर्ण प्रकार के संवाद बॉक्स का समर्थन करता है। इन डायलॉग बॉक्स का इस्तेमाल किसी भी इनपुट पर पुष्टि करने के लिए या किसी भी इनपुट पर पुष्टि करने के लिए या उपयोगकर्ताओं से एक तरह का इनपुट प्राप्त करने के लिए किया जा सकता है। यहां हम एक-एक करके हर डायलॉग बॉक्स पर चर्चा करेंगे।

अलर्ट डायलॉग बॉक्स

एक चेतावनी संवाद बॉक्स का उपयोग ज्यादातर उपयोगकर्ताओं को चेतावनी संदेश भेजने के लिए किया जाता है। उदाहरण के लिए, यदि एक इनपुट फ़ील्ड में कुछ पाठ दर्ज करने की आवश्यकता होती है, लेकिन उपयोगकर्ता कोई इनपुट प्रदान नहीं करता है, तो सत्यापन के एक भाग के रूप में, आप चेतावनी संदेश भेजने के लिए एक अलर्ट बॉक्स का उपयोग कर सकते हैं।

बहरहाल, एक मैसेज बॉक्स का उपयोग अभी भी मैत्रीपूर्ण संदेशों के लिए किया जा सकता है। अलर्ट बॉक्स चयन और आगे बढ़ने के लिए केवल एक बटन "ओके" प्रदान करता है।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function Warn() {  
            alert ("This is a warning message!");  
            document.write ("This is a warning message!");  
         } 
      </script> 
   </head> 

   <body> 
      <p>Click the following button to see the result: </p> 
      <form> 
         <input type = "button" value = "Click Me" onclick = "Warn();" /> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

पुष्टि संवाद बॉक्स

एक पुष्टिकरण संवाद बॉक्स का उपयोग किसी भी विकल्प पर उपयोगकर्ता की सहमति लेने के लिए किया जाता है। यह दो बटन के साथ एक संवाद बॉक्स प्रदर्शित करता है: ठीक है और रद्द करें।

यदि उपयोगकर्ता ठीक बटन पर क्लिक करता है, तो विंडो विधि confirm()सच लौटेगा। यदि उपयोगकर्ता रद्द करें बटन पर क्लिक करता है, तो पुष्टि करें () गलत देता है। आप निम्न प्रकार से एक पुष्टिकरण संवाद बॉक्स का उपयोग कर सकते हैं।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function getConfirmation(){  
            var retVal = confirm("Do you want to continue ?");  
            
            if( retVal == true ){  
               document.write ("User wants to continue!");  
               return true;  
            } else {  
               Document.write ("User does not want to continue!");  
               return false;  
            }  
         }  
      </script> 
   </head> 

   <body> 
      <p>Click the following button to see the result: </p> 
      <form> 
         <input type = "button" value = "Click Me" onclick = "getConfirmation();" /> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

शीघ्र संवाद बॉक्स

जब आप उपयोगकर्ता इनपुट प्राप्त करने के लिए टेक्स्ट बॉक्स को पॉप-अप करना चाहते हैं, तो प्रॉम्प्ट डायलॉग बॉक्स बहुत उपयोगी होता है। इस प्रकार, यह आपको उपयोगकर्ता के साथ बातचीत करने में सक्षम बनाता है। उपयोगकर्ता को फ़ील्ड में भरना होगा और फिर ओके पर क्लिक करना होगा।

यह डायलॉग बॉक्स नामक विधि का उपयोग करके प्रदर्शित किया जाता है prompt() जो दो पैरामीटर लेता है: (i) एक लेबल जिसे आप टेक्स्ट बॉक्स में प्रदर्शित करना चाहते हैं और (ii) टेक्स्ट बॉक्स में प्रदर्शित करने के लिए एक डिफ़ॉल्ट स्ट्रिंग।

इस संवाद बॉक्स में दो बटन हैं: ठीक है और रद्द करें। यदि उपयोगकर्ता ठीक बटन पर क्लिक करता है, तो विंडो विधि प्रॉम्प्ट () पाठ बॉक्स से दर्ज मूल्य वापस कर देगा। यदि उपयोगकर्ता रद्द करें बटन पर क्लिक करता है, तो विंडो विधि शीघ्र () वापस आती है।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         function getValue(){  
            var retVal = prompt("Enter your name : ", "your name here");  
            document.write("You have entered : " + retVal);  
         }  
      </script> 
   </head> 

   <body> 
      <p>Click the following button to see the result: </p> 
      <form> 
         <input type = "button" value = "Click Me" onclick = "getValue();" /> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

voidजावास्क्रिप्ट में एक महत्वपूर्ण कीवर्ड है जो एक एकल ऑपरेटर के रूप में इस्तेमाल किया जा सकता है जो इसके एकल ऑपरेंड से पहले दिखाई देता है, जो किसी भी प्रकार का हो सकता है। यह ऑपरेटर किसी मान को वापस किए बिना मूल्यांकन किए जाने के लिए एक अभिव्यक्ति निर्दिष्ट करता है। ऑपरेटर दी गई अभिव्यक्ति का मूल्यांकन करता है और फिर अपरिभाषित लौटता है।

निम्नलिखित के लिए सिंटैक्स है।

void expression

शून्य और तुरंत फ़ंक्शन अभिव्यक्तियाँ

एक तत्काल-आहरण फ़ंक्शन अभिव्यक्ति का उपयोग करते समय, शून्य का उपयोग फ़ंक्शन कीवर्ड को एक घोषणा के बजाय एक अभिव्यक्ति के रूप में व्यवहार करने के लिए मजबूर करने के लिए किया जा सकता है।

निम्नलिखित उदाहरण पर विचार करें -

void function iife_void() { 
   var msg = function () {console.log("hello world")}; 
   msg(); 
}();

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

hello world

शून्य और जावास्क्रिप्ट URI

JavaScript: URIएक HTML पृष्ठ में एक आम तौर पर सामना किया गया वाक्यविन्यास है। ब्राउज़र URI का मूल्यांकन करता है और पृष्ठ की सामग्री को बदले गए मान के साथ बदलता है। यह तब तक सही है जब तक कि लौटाया गया मान अपरिभाषित न हो। इस ऑपरेटर का सबसे आम उपयोग क्लाइंट-साइड में हैJavaScript: URL, जहां यह आपको मूल्यांकन किए गए अभिव्यक्ति के मूल्य को प्रदर्शित करने वाले ब्राउज़र के बिना इसके दुष्प्रभावों के लिए एक अभिव्यक्ति का मूल्यांकन करने की अनुमति देता है।

निम्नलिखित कोड स्निपेट पर विचार करें -

<a href = "javascript:void(javascript:alert('hello world!!'))"> 
  Click here to do nothing 
</a> 
<br/><br/><br/> 
<a href = "javascript:alert('hello');">Click here for an alert</a>

एक HTML दस्तावेज़ के रूप में उपरोक्त फ़ाइल को सहेजें और इसे ब्राउज़र में खोलें। पहले हाइपरलिंक, जब क्लिक किया जाता है तो जावास्क्रिप्ट का मूल्यांकन करता है: अलर्ट ("हैलो") और शून्य () ऑपरेटर के पास जाता है। हालाँकि, शून्य ऑपरेटर अपरिभाषित होने के बाद, पृष्ठ पर कोई परिणाम प्रदर्शित नहीं होता है।

दूसरी ओर, क्लिक किए जाने पर दूसरा हाइपरलिंक एक चेतावनी संवाद प्रदर्शित करता है।

कई बार आप अपने वेबपेज पर एक वास्तविक प्रिंटर के माध्यम से उस वेब पेज की सामग्री को प्रिंट करने के लिए एक बटन रखना चाहेंगे। जावास्क्रिप्ट आपको विंडो ऑब्जेक्ट के प्रिंट फ़ंक्शन का उपयोग करके इस कार्यक्षमता को लागू करने में मदद करता है।

जावास्क्रिप्ट प्रिंट समारोह window.print()निष्पादित होने पर वर्तमान वेबपेज को प्रिंट करता है। आप निम्न उदाहरण में दिखाए गए अनुसार ऑनक्लिक ईवेंट का उपयोग करके सीधे इस फ़ंक्शन को कॉल कर सकते हैं।

उदाहरण

<html> 
   <body> 
      <form> 
         <input type = "button" value = "Print" onclick = "window.print()"/> 
      </form> 
   </body> 
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

जावास्क्रिप्ट डेटा प्रकार का विस्तार करता है। जावास्क्रिप्ट ऑब्जेक्ट कस्टम डेटा प्रकारों को परिभाषित करने का एक शानदार तरीका है।

एक objectएक उदाहरण है जिसमें मुख्य मूल्य जोड़े का एक सेट होता है। आदिम डेटा प्रकारों के विपरीत, ऑब्जेक्ट कई या जटिल मूल्यों का प्रतिनिधित्व कर सकते हैं और अपने जीवन काल में बदल सकते हैं। मान स्केलर मान या फ़ंक्शन या अन्य ऑब्जेक्ट्स की सरणी भी हो सकते हैं।

किसी वस्तु को परिभाषित करने के लिए वाक्यात्मक रूपांतरों पर आगे चर्चा की गई है।

ऑब्जेक्ट शुरुआती

आदिम प्रकारों की तरह, वस्तुओं का शाब्दिक वाक्य-विन्यास होता है: curly bracesv({तथा})। किसी वस्तु को परिभाषित करने के लिए वाक्य रचना निम्नलिखित है।

var identifier = {
   Key1:value, Key2: function () { 
      //functions 
   }, 
   Key3: [“content1”,” content2”] 
}

किसी वस्तु की सामग्री को कहा जाता है properties (या सदस्य), और गुण एक से मिलकर होते हैं name (या कुंजी) और value। संपत्ति के नाम तार या प्रतीक होने चाहिए, और मान किसी भी प्रकार (अन्य वस्तुओं सहित) हो सकते हैं।

सभी जावास्क्रिप्ट चर की तरह, वस्तु का नाम (जो एक सामान्य चर हो सकता है) और संपत्ति का नाम दोनों संवेदनशील हैं। आप एक साधारण डॉट-नोटेशन के साथ किसी ऑब्जेक्ट के गुणों को एक्सेस करते हैं।

ऑब्जेक्ट गुण तक पहुँचने के लिए सिंटैक्स निम्नलिखित है।

objectName.propertyName

उदाहरण: ऑब्जेक्ट इनिशियलाइज़र

var person = { 
   firstname:"Tom", 
   lastname:"Hanks", 
   func:function(){return "Hello!!"},    
}; 
//access the object values 
console.log(person.firstname)   
console.log(person.lastname) 
console.log(person.func())

उपरोक्त उदाहरण, एक वस्तु व्यक्ति को परिभाषित करता है। वस्तु में तीन गुण होते हैं। तीसरी संपत्ति एक फ़ंक्शन को संदर्भित करती है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Tom 
Hanks 
Hello!!

ईएस 6 में, एक संपत्ति मूल्य निर्दिष्ट करना जो एक संपत्ति के नाम से मेल खाता है, आप संपत्ति मूल्य को छोड़ सकते हैं।

उदाहरण

var foo = 'bar' 
var baz = { foo } 
console.log(baz.foo)

उपरोक्त कोड स्निपेट किसी वस्तु को परिभाषित करता है baz। वस्तु का एक गुण होता हैfoo। संपत्ति मूल्य को यहां छोड़ दिया गया है क्योंकि ES6 स्पष्ट रूप से वस्तु के प्रमुख फू को चर foo का मूल्य प्रदान करता है।

निम्नलिखित उपरोक्त कोड के बराबर ES5 है।

var foo = 'bar' 
var baz = { foo:foo } 
console.log(baz.foo)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

bar

इस शॉर्टहैंड सिंटैक्स के साथ, जेएस इंजन एक ही नाम के साथ एक चर के लिए युक्त दायरे में दिखता है। यदि यह पाया जाता है, कि चर का मूल्य संपत्ति को सौंपा गया है। यदि यह नहीं पाया जाता है, तो एक संदर्भ त्रुटि फेंक दी जाती है।

ऑब्जेक्ट () कंस्ट्रक्टर

जावास्क्रिप्ट एक विशेष रचनाकार फ़ंक्शन प्रदान करता है जिसे कहा जाता है Object()वस्तु बनाने के लिए। नए ऑपरेटर का उपयोग किसी वस्तु का उदाहरण बनाने के लिए किया जाता है। ऑब्जेक्ट बनाने के लिए, नए ऑपरेटर का निर्माण विधि द्वारा किया जाता है।

किसी वस्तु को परिभाषित करने के लिए वाक्य रचना निम्नलिखित है।

var obj_name = new Object(); 
obj_name.property = value;    
OR             
obj_name["key"] = value

निम्नलिखित एक संपत्ति तक पहुँचने के लिए वाक्यविन्यास है।

Object_name.property_key                    
OR              
Object_name["property_key"]

उदाहरण

var myCar = new Object(); 
myCar.make = "Ford"; //define an object 
myCar.model = "Mustang"; 
myCar.year = 1987;  

console.log(myCar["make"]) //access the object property 
console.log(myCar["model"]) 
console.log(myCar["year"])

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Ford 
Mustang 
1987

किसी वस्तु के अनिर्दिष्ट गुण अपरिभाषित होते हैं।

उदाहरण

var myCar = new Object(); 
myCar.make = "Ford"; 
console.log(myCar["model"])

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

undefined

Note- एक ऑब्जेक्ट प्रॉपर्टी का नाम किसी भी मान्य जावास्क्रिप्ट स्ट्रिंग, या कुछ भी हो सकता है जिसे रिक्त स्ट्रिंग सहित स्ट्रिंग में परिवर्तित किया जा सकता है। हालांकि, कोई भी संपत्ति का नाम जो मान्य जावास्क्रिप्ट पहचानकर्ता नहीं है (उदाहरण के लिए, एक संपत्ति नाम जिसमें एक स्थान या एक हाइफ़न है, या जो एक संख्या से शुरू होता है) केवल स्क्वायर ब्रैकेट नोटेशन का उपयोग करके पहुँचा जा सकता है।

एक चर में संग्रहीत स्ट्रिंग मान का उपयोग करके गुण भी प्राप्त किए जा सकते हैं। दूसरे शब्दों में, ऑब्जेक्ट की संपत्ति कुंजी एक गतिशील मूल्य हो सकती है। उदाहरण के लिए: एक चर। उक्त अवधारणा निम्नलिखित उदाहरण में सचित्र है।

उदाहरण

var myCar = new Object()  
var propertyName = "make"; 
myCar[propertyName] = "Ford"; 
console.log(myCar.make)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Ford

कंस्ट्रक्टर फंक्शन

निम्नलिखित दो चरणों का उपयोग करके एक वस्तु बनाई जा सकती है -

Step 1 - एक कंस्ट्रक्टर फ़ंक्शन लिखकर ऑब्जेक्ट प्रकार को परिभाषित करें।

निम्नलिखित के लिए सिंटैक्स है।

function function_name() { 
   this.property_name = value 
}

‘this’ कीवर्ड उपयोग में वर्तमान ऑब्जेक्ट को संदर्भित करता है और ऑब्जेक्ट की संपत्ति को परिभाषित करता है।

Step 2 - नए सिंटैक्स के साथ ऑब्जेक्ट का एक उदाहरण बनाएं।

var Object_name= new function_name() 
//Access the property value  

Object_name.property_name

नया कीवर्ड फ़ंक्शन कंस्ट्रक्टर को आमंत्रित करता है और फ़ंक्शन की प्रॉपर्टी कीज़ को इनिशियलाइज़ करता है।

Example − Using a Function Constructor

function Car() { 
   this.make = "Ford" 
   this.model = "F123" 
}  
var obj = new Car() 
console.log(obj.make) 
console.log(obj.model)

उपरोक्त उदाहरण किसी ऑब्जेक्ट को परिभाषित करने के लिए फ़ंक्शन कंस्ट्रक्टर का उपयोग करता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Ford 
F123

एक नई संपत्ति हमेशा एक पहले से परिभाषित वस्तु में जोड़ी जा सकती है। उदाहरण के लिए, निम्नलिखित कोड स्निपेट पर विचार करें -

function Car() { 
   this.make = "Ford" 
} 
var obj = new Car() 
obj.model = "F123" 
console.log(obj.make) 
console.log(obj.model)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Ford 
F123

Object.create विधि

वस्तुओं का उपयोग करके भी बनाया जा सकता है Object.create()तरीका। यह आपको एक निर्माता फ़ंक्शन को परिभाषित किए बिना, इच्छित ऑब्जेक्ट के लिए प्रोटोटाइप बनाने की अनुमति देता है।

उदाहरण

var roles = { 
   type: "Admin", // Default value of properties 
   displayType : function() {  
      // Method which will display type of role 
      console.log(this.type); 
   } 
}  
// Create new role type called super_role 
var super_role = Object.create(roles); 
super_role.displayType(); // Output:Admin  

// Create new role type called Guest 
var guest_role = Object.create(roles); 
guest_role.type = "Guest"; 
guest_role.displayType(); // Output:Guest

उपरोक्त उदाहरण एक ऑब्जेक्ट को परिभाषित करता है और गुण के लिए डिफ़ॉल्ट मान सेट करता है। दो नए उदाहरण बनाए जाते हैं जो ऑब्जेक्ट के लिए डिफ़ॉल्ट गुण मान को ओवरराइड करते हैं।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Admin 
Guest

Object.assign () फ़ंक्शन

Object.assign()विधि का उपयोग एक या एक से अधिक स्रोत वस्तुओं से लक्ष्य वस्तु तक सभी गणना करने योग्य गुणों के मूल्यों को कॉपी करने के लिए किया जाता है। यह लक्ष्य वस्तु को लौटा देगा।

निम्नलिखित के लिए सिंटैक्स है।

Object.assign(target, ...sources)

Example − Cloning an Object

"use strict" 
var det = { name:"Tom", ID:"E1001" }; 
var copy = Object.assign({}, det); 
console.log(copy);  
for (let val in copy) { 
   console.log(copy[val]) 
}

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Tom 
E1001

Example − Merging Objects

var o1 = { a: 10 }; 
var o2 = { b: 20 }; 
var o3 = { c: 30 }; 
var obj = Object.assign(o1, o2, o3); 
console.log(obj);  
console.log(o1);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

{ a: 10, b: 20, c: 30 } 
{ a: 10, b: 20, c: 30 }

Note- वस्तुओं की नकल करने के विपरीत, जब वस्तुओं का विलय हो जाता है, तो बड़ी वस्तु गुणों की एक नई प्रतिलिपि को बनाए नहीं रखती है। बल्कि यह मूल वस्तुओं में निहित गुणों का संदर्भ रखता है। निम्नलिखित उदाहरण इस अवधारणा की व्याख्या करता है।

var o1 = { a: 10 }; 
var obj = Object.assign(o1); 
obj.a++ 
console.log("Value of 'a' in the Merged object after increment  ") 
console.log(obj.a);  
console.log("value of 'a' in the Original Object after increment ") 
console.log(o1.a);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Value of 'a' in the Merged object after increment 
11  
value of 'a' in the Original Object after increment 
11

गुण हटाना

आप डिलीट ऑपरेटर का उपयोग करके एक संपत्ति निकाल सकते हैं। निम्न कोड दिखाता है कि किसी संपत्ति को कैसे निकालना है।

उदाहरण

// Creates a new object, myobj, with two properties, a and b. 
var myobj = new Object; 
myobj.a = 5; 
myobj.b = 12; 

// Removes the ‘a’ property 
delete myobj.a; 
console.log ("a" in myobj) // yields "false"

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

false

कोड स्निपेट ऑब्जेक्ट से संपत्ति को हटा देता है। ऑपरेटर में ऑब्जेक्ट के रूप में गुण नहीं ढूंढता उदाहरण गलत है।

वस्तुओं की तुलना करना

जावास्क्रिप्ट में, ऑब्जेक्ट एक संदर्भ प्रकार हैं। दो अलग-अलग वस्तुएं कभी भी समान नहीं होती हैं, भले ही उनके समान गुण हों। ऐसा इसलिए है, क्योंकि वे पूरी तरह से अलग मेमोरी एड्रेस की ओर इशारा करते हैं। केवल उन वस्तुओं को जो एक सामान्य संदर्भ साझा करते हैं, तुलना पर सच है।

Example 1 − Different Object References

var val1 = {name: "Tom"}; 
var val2 = {name: "Tom"}; 
console.log(val1 == val2)  // return false 
console.log(val1 === val2)  // return false

उपरोक्त उदाहरण में, val1 तथा val2दो अलग-अलग ऑब्जेक्ट हैं जो दो अलग-अलग मेमोरी एड्रेस को संदर्भित करते हैं। इसलिए समानता के लिए तुलना करने पर, ऑपरेटर गलत वापस आ जाएगा।

Example 2 − Single Object Reference

var val1 = {name: "Tom"}; 
var val2 = val1  

console.log(val1 == val2) // return true 
console.log(val1 === val2) // return true

उपरोक्त उदाहरण में, val1 में सामग्री को val2 को सौंपा गया है, अर्थात val1 में गुणों के संदर्भ को val2 के साथ साझा किया गया है। चूंकि, ऑब्जेक्ट अब संपत्ति के संदर्भ को साझा करते हैं, समानता ऑपरेटर दो अलग-अलग ऑब्जेक्ट्स के लिए सही लौटेगा जो दो अलग-अलग मेमोरी एड्रेस को संदर्भित करता है। इसलिए समानता के लिए तुलना करने पर, ऑपरेटर गलत वापस आ जाएगा।

ऑब्जेक्ट डी-स्ट्रक्चरिंग

अवधि destructuringएक इकाई की संरचना को तोड़ने के लिए संदर्भित करता है। जावास्क्रिप्ट में विनाशकारी असाइनमेंट सिंटैक्स, सरणियों या वस्तुओं से अलग-अलग चर में डेटा निकालने के लिए संभव बनाता है। इसका उदाहरण निम्नलिखित उदाहरण में दिया गया है।

उदाहरण 1

जब किसी ऑब्जेक्ट को नष्ट करना चर नाम और ऑब्जेक्ट प्रॉपर्टी के नाम से मेल खाना चाहिए।

<script>
let student = {
   rollno:20,
   name:'Prijin',
   cgpa:7.2
}

//destructuring to same property name
   let {name,cgpa} = student
   console.log(name)
   console.log(cgpa)

//destructuring to different name
   let {name:student_name,cgpa:student_cgpa}=student
   console.log(student_cgpa)
   console.log("student_name",student_name)
</script>

उपरोक्त कोड का आउटपुट नीचे देखा जाएगा -

Prijin
7.2
7.2
student_name Prijin

उदाहरण 2

यदि चर और असाइनमेंट दो अलग-अलग चरणों में हैं, तो विनाशकारी वस्तु सिंटैक्स को घेर लिया जाएगा () जैसा कि उदाहरण में दिखाया गया है ({rollno} = student) -

<script>
   let student = {
      rollno:20,
      name:'Prijin',
      cgpa:7.2
   }

   // destructuring to already declared variable
   let rollno;
   ({rollno} = student)
   console.log(rollno)

   // assign default values to variables

   let product ={ id:1001,price:2000} //discount is not product property
   let {id,price,discount=.10} = product
   console.log(id)
   console.log(price)
   console.log(discount)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

20
1001
2000
0.1

उदाहरण 3

नीचे का उदाहरण दिखाता है destructuring का उपयोग करते हुए rest operator और नेस्टेड वस्तुओं को कैसे नष्ट किया जाए।

<script>
   // rest operator with object destructuring
   let customers= {
      c1:101,
      c2:102,
      c3:103
   }

   let {c1,...others} = customers
   console.log(c1)
   console.log(others)

   //nested objects
   let emp = {
      id:101,
      address:{
         city:'Mumbai',
         pin:1234
      }
   }
   let {address} = emp;

   console.log(address)
   let {address:{city,pin}} = emp
   console.log(city)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

101
{c2: 102, c3: 103}
{city: "Mumbai", pin: 1234}
Mumbai

संख्या ऑब्जेक्ट संख्यात्मक तिथि, पूर्णांक या फ्लोटिंग-पॉइंट संख्याओं का प्रतिनिधित्व करता है। सामान्य तौर पर, आपको संख्या वस्तुओं के बारे में चिंता करने की आवश्यकता नहीं है क्योंकि ब्राउज़र स्वचालित रूप से संख्या वर्ग के उदाहरणों के लिए नंबर शाब्दिक रूप से परिवर्तित होता है।

नंबर ऑब्जेक्ट बनाने के लिए सिंटैक्स निम्नलिखित है।

var val = new Number(number);

की जगह पर number, यदि आप कोई गैर-संख्या तर्क प्रदान करते हैं, तो तर्क को एक में परिवर्तित नहीं किया जा सकता है number, यह NaN (नॉट-ए-नंबर) लौटाता है।

संख्या गुण

अनु क्रमांक संपत्ति विवरण
1 Number.EPSILON

दो प्रतिनिधित्व योग्य संख्याओं के बीच का सबसे छोटा अंतराल।

2 Number.MAX_SAFE_INTEGER

जावास्क्रिप्ट में अधिकतम सुरक्षित पूर्णांक (2 ^ 53 - 1)।

3 Number.MAX_VALUE

सबसे बड़ी सकारात्मक प्रतिनिधित्व योग्य संख्या।

4 MIN_SAFE_INTEGER

जावास्क्रिप्ट में न्यूनतम सुरक्षित पूर्णांक (- (2 ^ 53 - 1))।

5 Number.MIN_VALUE

सबसे छोटी पॉज़िटिव रिप्लेसेबल नंबर - यानी पॉज़िटिव नंबर ज़ीरो के सबसे नज़दीक (वास्तव में शून्य होने के बिना)

6 Number.Nan

विशेष "एक संख्या नहीं" मान

7 Number.NEGATIVE_INFINITY

नकारात्मक अनंत का प्रतिनिधित्व करने वाला विशेष मूल्य; अतिप्रवाह पर वापस लौटा

8 Number.POSITIVE_INFINITY

अनंत का प्रतिनिधित्व करने वाला विशेष मूल्य; अतिप्रवाह पर वापस लौटा

9 Number.prototype

अनंत का प्रतिनिधित्व करने वाला विशेष मूल्य; अतिप्रवाह पर वापस लौटा

संख्या विधियाँ

अनु क्रमांक विधि और विवरण
1 Number.isNaN ()

निर्धारित करता है कि पारित मूल्य NaN है या नहीं।

2 Number.isFinite ()

निर्धारित करता है कि पारित मूल्य एक परिमित संख्या है।

3 Number.isInteger ()

निर्धारित करता है कि पारित मूल्य एक पूर्णांक है या नहीं।

4 Number.isSafeInteger ()

निर्धारित करता है कि पारित मूल्य एक सुरक्षित पूर्णांक है ((253 - 1) और 253- 1 के बीच की संख्या)

5 Number.parseFloat ()

मान वैश्विक ऑब्जेक्ट के parseFloat () के समान है

6 Number.parseInt ()

मान वैश्विक ऑब्जेक्ट के parseInt () के समान है

संख्या उदाहरण के तरीके

संख्या ऑब्जेक्ट में केवल डिफ़ॉल्ट विधियाँ होती हैं जो हर ऑब्जेक्ट की परिभाषा का एक हिस्सा होती हैं।

अनु क्रमांक उदाहरण विधि और विवरण
1 toExponential ()

घातीय संकेतन में संख्या का प्रतिनिधित्व करने वाला एक स्ट्रिंग देता है

2 toFixed ()

निश्चित-बिंदु संकेतन में संख्या का प्रतिनिधित्व करने वाला एक स्ट्रिंग देता है

3 toLocaleString ()

इस संख्या के भाषा संवेदनशील प्रतिनिधित्व के साथ एक स्ट्रिंग लौटाता है

4 toPrecision ()

निश्चित-बिंदु या घातीय संकेतन में एक निर्दिष्ट परिशुद्धता के लिए संख्या का प्रतिनिधित्व करने वाला एक स्ट्रिंग देता है

5 तार()

निर्दिष्ट मूलांक (बेस) में निर्दिष्ट वस्तु का प्रतिनिधित्व करने वाला एक स्ट्रिंग लौटाता है

6 का मूल्य()

निर्दिष्ट वस्तु का मौलिक मान वापस करता है।

बाइनरी और ऑक्टल लिटरल

ES6 से पहले, आपका सबसे अच्छा दांव जब पूर्णांक के बाइनरी या ऑक्टल प्रतिनिधित्व की बात आती है, तो बस उन्हें मूलांक के साथ parseInt () में पास करना था। ES6 में, आप क्रमशः बाइनरी और ऑक्टल पूर्णांक शाब्दिक का प्रतिनिधित्व करने के लिए 0b और 0o उपसर्ग का उपयोग कर सकते हैं। इसी तरह, एक हेक्साडेसिमल मान का प्रतिनिधित्व करने के लिए, का उपयोग करें0x उपसर्ग।

उपसर्ग ऊपरी या निचले मामले में लिखा जा सकता है। हालांकि, यह लोअरकेस संस्करण से चिपके रहने का सुझाव दिया गया है।

Example − Binary Representation

console.log(0b001) 
console.log(0b010) 
console.log(0b011) 
console.log(0b100)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

1 
2 
3 
4

Example − Octal Representation

console.log(0o010)
console.log(0o100)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

8
64

Example − Hexadecimal Representation

console.log(0o010)
console.log(0o100)

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

255
384

वस्तु शाब्दिक विस्तार

ES6 निम्नलिखित का परिचय देता है syntax changes वस्तु शाब्दिक घोषणा में।

  • ऑब्जेक्ट प्रॉपर्टी इनिशियलाइज़र सिंटैक्स
  • कम्प्यूटेड गुण वाक्यविन्यास
  • संक्षिप्त विधि सिंटैक्स

ऑब्जेक्ट प्रॉपर्टी इनिशियलाइज़र

में object property initializer syntax, हम चर के साथ सीधे एक वस्तु को इनिशियलाइज़ कर सकते हैं। यह उन विशेषताओं का निर्माण करेगा जिनका चर के समान नाम है।

<script>
   let firstName = 'Tutorials',lastName='Point'
   let company = {
      firstName,
      lastName
   }
   console.log(company)
   console.log(company.firstName)
   console.log(company.lastName)
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

{firstName: "Tutorials", lastName: "Point"}
Tutorials
Point

संगणित गुण

में computed properties syntaxवस्तु की संपत्ति गतिशील रूप से चर से बनाई जा सकती है। निम्नलिखित उदाहरण में, नाम से एक चरsuffix की गणना करने के लिए उपयोग किया जाता है company वस्तु।

<script>
   let suffix = 'Name'
   let company = {
      ['first'+suffix]:'Tutorials',
      ['last'+suffix]:'Point'
   }
   console.log(company)
   console.log(company['firstName'])
   console.log(company['lastName'])
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

{firstName: "Tutorials", lastName: "Point"}
Tutorials
Point

में Concise method syntax हम उपयोग के बिना सीधे एक विधि का उपयोग और घोषित कर सकते हैं functionकीवर्ड। यह वस्तु शाब्दिक में कार्यों को शामिल करने के लिए एक सरलीकृत वाक्यविन्यास है।

<script>
   let firstName = 'Tutorials',lastName='Point'
   let company = {
      firstName,
      lastName,
      getFullName(){
         return this.firstName+" - "+this.lastName
      }
   }
   console.log(company.getFullName())
   console.log(company)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

Tutorials - Point
{firstName: "Tutorials", lastName: "Point", getFullName: ƒ}

बुलियन ऑब्जेक्ट या तो दो मूल्यों का प्रतिनिधित्व करता है "true" या "false"। यदि मान पैरामीटर छोड़ा गया है या 0, -0, अशक्त, गलत, NaN, अपरिभाषित या रिक्त स्ट्रिंग ("") है, तो ऑब्जेक्ट में गलत का प्रारंभिक मान है।

A बनाने के लिए निम्न सिंटैक्स का उपयोग करें boolean object

var val = new Boolean(value);

बूलियन गुण

निम्नलिखित बूलियन ऑब्जेक्ट के गुणों की एक सूची है।

अनु क्रमांक संपत्ति विवरण
1 constructor

Returns a reference to the Boolean function that created the object.

2 prototype

The prototype property allows you to add properties and methods to an object.

Boolean Methods

Following is a list of the methods of Boolean object and their description.

Sr.No Method & Description
1 toSource()

Returns a string containing the source of the Boolean object; you can use this string to create an equivalent object.

2 toString()

Returns a string of either "true" or "false" depending upon the value of the object.

3 valueOf()

Returns the primitive value of the Boolean object.

In the following sections, we will take a look at a few examples to demonstrate the usage of the Boolean methods.

The String object lets you work with a series of characters; it wraps JavaScript’s string primitive data type with a number of helper methods.

As JavaScript automatically converts between string primitives and String objects, you can call any of the helper methods of the String object on a string primitive.

Use the following syntax to create a String object.

var val = new String(string);

The string parameter is a series of characters that has been properly encoded. String.

String Properties

Following is a list of the properties of String object and its description.

Sr.No Property & Description
1 constructor

Returns a reference to the String function that created the object .

2 length

Returns the length of the string.

3 Prototype

The prototype property allows you to add properties and methods to an object .

String Methods

Here is a list of the methods available in String object along with their description.

Sr.No Method & Description
1 charAt()

Returns the character at the specified index.

2 charCodeAt()

Returns a number indicating the Unicode value of the character at the given index.

3 concat()

Combines the text of two strings and returns a new string.

4 indexOf()

Returns the index within the calling String object of the first occurrence of the specified value, or -1 if not found.

5 lastIndexOf()

Returns the index within the calling String object of the last occurrence of the specified value, or -1 if not found.

6 localeCompare()

Returns a number indicating whether a reference string comes before or after or is the same as the given string in a sorted order.

7 match()

Used to match a regular expression against a string.

8 replace()

Used to find a match between a regular expression and a string, and to replace the matched substring with a new substring.

9 search()

Executes the search for a match between a regular expression and a specified string.

10 slice()

Extracts a section of a string and returns a new string.

11 split()

Splits a String object into an array of strings by separating the string into substrings.

12 substr()

Returns the characters in a string beginning at the specified location through the specified number of characters.

13 substring()

Returns the characters in a string between two indexes into the string.

14 toLocaleLowerCase()

The characters within a string are converted to lower case while respecting the current locale.

15 toLocaleupperCase()

The characters within a string are converted to uppercase while respecting the current locale.

16 toLowerCase()

Returns the calling string value converted to lowercase.

17 toString()

Returns a string representing the specified object.

18 toUpperCase()

Returns the calling string value converted to uppercase.

19 valueOf()

Returns the primitive value of the specified object.

Introduction to Symbol

ES6 introduces a new primitive type called Symbol. They are helpful to implement metaprogramming in JavaScript programs.

Syntax

const mySymbol = Symbol()
const mySymbol = Symbol(stringDescription)

A symbol is just a piece of memory in which you can store some data. Each symbol will point to a different memory location. Values returned by a Symbol() constructor are unique and immutable.

Example

Let us understand this through an example. Initially, we created two symbols without description followed by symbols with same description. In both the cases the equality operator will return false when the symbols are compared.

<script>
   const s1 = Symbol();
   const s2 = Symbol();
   console.log(typeof s1)
   console.log(s1===s2)
   const s3 = Symbol("hello");//description
   const s4 = Symbol("hello");
   console.log(s3)
   console.log(s4)
   console.log(s3==s4)
</script>

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

symbol
false
Symbol(hello)
Symbol(hello)
false
Sr.No Property & Description
1 Symbol.for(key)

searches for existing symbols in a symbol registry with the given key and returns it, if found. Otherwise, a new symbol gets created in the global symbol registry with this key.

2 Symbol.keyFor(sym)

Retrieves a shared symbol key from the global symbol registry for the given symbol.

Symbol & Classes

A symbol can be used with classes to define the properties in the class. The advantage is that if property is a symbol as shown below, the property can be accessed outside the package only if the symbol name is known. So, data is much encapsulated when symbols are used as properties.

Example

<script>
   const COLOR = Symbol()
   const MODEL = Symbol()
   const MAKE = Symbol()
   class Bike {
      constructor(color ,make,model){
      this[COLOR] = color;
      this[MAKE] = make;
      this[MODEL] = model;
   }
}
let bike = new Bike('red','honda','cbr')
console.log(bike)
//property can be accessed ony if symbol name is known
console.log(bike[COLOR])
</script>

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

Bike {Symbol(): "red", Symbol(): "honda", Symbol(): "cbr"}
red

Following is a list of methods with their description.

Sr.No Method & Description
1 String.prototype.startsWith(searchString, position = 0)

Returns true if the receiver starts with searchString; the position lets you specify where the string to be checked starts.

2 String.prototype.endsWith(searchString, endPosition = searchString.length)

Returns true if the receiver starts with searchString; the position lets you specify where the string to be checked starts.

3 String.prototype.includes(searchString, position = 0)

Returns true if the receiver contains searchString; position lets you specify where the string to be searched starts.

4 String.prototype.repeat(count)

Returns the receiver, concatenated count times.

Template Literals

Template literals are string literals that allow embedded expressions. Templatestrings use back-ticks (``) rather than the single or double quotes. A template string could thus be written as −

var greeting = `Hello World!`;

String Interpolation and Template literals

Template strings can use placeholders for string substitution using the ${ } syntax, as demonstrated.

Example 1

var name = "Brendan"; 
console.log('Hello, ${name}!');

The following output is displayed on successful execution of the above code.

Hello, Brendan!

Example 2: Template literals and expressions

var a = 10; 
var b = 10; 
console.log(`The sum of ${a} and ${b} is ${a+b} `);

The following output is displayed on successful execution of the above code.

The sum of 10 and 10 is 20

Example 3: Template literals and function expression

function fn() { return "Hello World"; } 
console.log(`Message: ${fn()} !!`);

The following output is displayed on successful execution of the above code.

Message: Hello World !!

Multiline Strings and Template Literals

Template strings can contain multiple lines.

Example

var multiLine = `
   This is 
   a string 
   with multiple 
   lines`; 
console.log(multiLine)

The following output is displayed on successful execution of the above code.

This is 
a string 
with multiple 
line

String.raw()

ES6 includes the tag function String.raw for raw strings, where backslashes have no special meaning. String.raw enables us to write the backslash as we would in a regular expression literal. Consider the following example.

var text =`Hello \n World` 
console.log(text)  

var raw_text = String.raw`Hello \n World ` 
console.log(raw_text)

The following output is displayed on successful execution of the above code.

Hello 
World 
Hello \n World

Tagged Templates

A tag is a function which can interpret and process a template literal. A tag appears in front of the template literal. Syntax is shown below.

Syntax

let output_fromTag = tagFunction `Template literal with ${variable1} , ${variable2}`

The tag function implementation syntax is as given below −

function tagFunction(literals,...variable_values){
   //process
   return "some result"
}

Example

Following Example defines a tag function myTagFn(). It displays the parameters passed to it. After displaying it returns Done to the caller.

<script>
   function myTagFn(literals,...values){
      console.log("literal values are");
      for(let c of literals){
         console.log(c)
      }

      console.log("variable values are ");
      for(let c of values){
         console.log(c)
      }

      return "Done"
   }
   let company = `TutorialsPoint`
   let company_location = `Mumbai`
   let result = myTagFn `Hello this is ${company} from ${company_location}`

   console.log(result)

</script>

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

//literal
literal values are
Hello this is
from
//values
variable values are
TutorialsPoint
Mumbai
Done

Example

The below tag function takes a template literal and converts it to upper case as shown below −

<script>
   function convertToUpperTagFn(literals, ...values) {
      let result = "";
      for (let i = 0; i < literals.length; i++) {
         result += literals[i];
         if (i < values.length) {
            result += values[i];
         }
      }
      return result.toUpperCase();
   }
   let company = `TutorialsPoint`
   let company_location = `Mumbai`
   let result = convertToUpperTagFn `Hello this is ${company} from ${company_location}`

   console.log(result)

</script>

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

HELLO THIS IS TUTORIALSPOINT FROM MUMBAI

String.fromCodePoint()

The static String.fromCodePoint() method returns a string created by using the specified sequence of unicode code points. The function throws a RangeError if an invalid code point is passed.

console.log(String.fromCodePoint(42))        
console.log(String.fromCodePoint(65, 90))

The following output is displayed on successful execution of the above code.

* 
AZ

The use of variables to store values poses the following limitations −

  • Variables are scalar in nature. In other words, a variable declaration can only contain a single at a time. This means that to store n values in a program, n variable declarations will be needed. Hence, the use of variables is not feasible when one needs to store a larger collection of values.

  • Variables in a program are allocated memory in random order, thereby making it difficult to retrieve/read the values in the order of their declaration.

JavaScript introduces the concept of arrays to tackle the same.

An array is a homogenous collection of values. To simplify, an array is a collection of values of the same data type. It is a user-defined type.

Features of an Array

  • An array declaration allocates sequential memory blocks.

  • Arrays are static. This means that an array once initialized cannot be resized.

  • Each memory block represents an array element.

  • Array elements are identified by a unique integer called as the subscript/index of the element.

  • Arrays too, like variables, should be declared before they are used.

  • Array initialization refers to populating the array elements.

  • Array element values can be updated or modified but cannot be deleted.

Declaring and Initializing Arrays

To declare and initialize an array in JavaScript use the following syntax −

var array_name; //declaration 
array_name = [val1,val2,valn..]   //initialization 
OR 
var array_name = [val1,val2…valn]

Note − The pair of [] is called the dimension of the array.

For example, a declaration like: var numlist = [2,4,6,8] will create an array as shown in the following figure.

Accessing Array Elements

The array name followed by the subscript is used to refer to an array element.

Following is the syntax for the same.

array_name[subscript]

Example: Simple Array

var alphas; 
alphas = ["1","2","3","4"] 
console.log(alphas[0]); 
console.log(alphas[1]);

The following output is displayed on successful execution of the above code.

1 
2

Example: Single Statement Declaration and Initialization

var nums = [1,2,3,3] 
console.log(nums[0]); 
console.log(nums[1]); 
console.log(nums[2]); 
console.log(nums[3]);

The following output is displayed on successful execution of the above code.

1 
2 
3 
3

Array Object

An array can also be created using the Array object. The Array constructor can be passed as −

  • A numeric value that represents the size of the array or.

  • A list of comma separated values.

The following Examples create an array using this method.

Example

var arr_names = new Array(4)  
for(var i = 0;i<arr_names.length;i++) { 
   arr_names[i] = i * 2 
   console.log(arr_names[i]) 
}

The following output is displayed on successful execution of the above code.

0 
2 
4 
6

Example: Array Constructor Accepts Comma-separated Values

var names = new Array("Mary","Tom","Jack","Jill") 
for(var i = 0;i<names.length;i++) { 
   console.log(names[i]) 
}

The following output is displayed on successful execution of the above code.

Mary 
Tom 
Jack 
Jill

Array Methods

Following is the list of the methods of the Array object along with their description.

Sr.No Method & Description
1 concat()

Returns a new array comprised of this array joined with other array(s) and/or value(s)

2 every()

Returns true if every element in this array satisfies the provided testing function.

3 filter()

Creates a new array with all of the elements of this array for which the provided filtering function returns true.

4 forEach()

Calls a function for each element in the array.

5 indexOf()

Returns the first (least) index of an element within the array equal to the specified value, or -1 if none is found.

6 join()

Joins all elements of an array into a string.

7 lastIndexOf()

Returns the last (greatest) index of an element within the array equal to the specified value, or -1 if none is found.

8 map()

Creates a new array with the results of calling a provided function on every element in this array.

9 pop()

Removes the last element from an array and returns that element.

10 push()

Adds one or more elements to the end of an array and returns the new length of the array.

11 reduce()

Applies a function simultaneously against two values of the array (from left-to-right) as to reduce it to a single value.

12 reduceRight()

Applies a function simultaneously against two values of the array (from right-to-left) as to reduce it to a single value.

13 reverse()

Reverses the order of the elements of an array -- the first becomes the last, and the last becomes the first.

14 shift()

Removes the first element from an array and returns that element slice.

15 slice()

Extracts a section of an array and returns a new array.

16 some()

Returns true if at least one element in this array satisfies the provided testing function.

17

toSource()

Represents the source code of an object.

18 sort()

Sorts the elements of an array.

19 splice()

Adds and/or removes elements from an array.

20 toString()

Returns a string representing the array and its elements.

21 unshift()

Adds one or more elements to the front of an array and returns the new length of the array.

ES6 − Array Methods

Following are some new array methods introduced in ES6.

Array.prototype.find

find lets you iterate through an array and get the first element back that causes the given callback function to return true. Once an element has been found, the function immediately returns. It’s an efficient way to get at just the first item that matches a given condition.

Example

var numbers = [1, 2, 3]; 
var oddNumber = numbers.find((x) => x % 2 == 1); 
console.log(oddNumber); // 1

The following output is displayed on successful execution of the above code.

1

Note − The ES5 filter() and the ES6 find() are not synonymous. Filter always returns an array of matches (and will return multiple matches), find always returns the actual element.

Array.prototype.findIndex

findIndex behaves similar to find, but instead of returning the element that matched, it returns the index of that element.

var numbers = [1, 2, 3]; 
var oddNumber = numbers.findIndex((x) => x % 2 == 1); 
console.log(oddNumber); // 0

The above example will return the index of the value 1 (0) as output.

Array.prototype.entries

entries is a function that returns an Array Iterator that can be used to loop through the array’s keys and values. Entries will return an array of arrays, where each child array is an array of [index, value].

var numbers = [1, 2, 3]; 
var val = numbers.entries(); 
console.log(val.next().value);  
console.log(val.next().value);  
console.log(val.next().value);

The following output is displayed on successful execution of the above code.

[0,1] 
[1.2] 
[2,3]

Alternatively, we can also use the spread operator to get back an array of the entries in one go.

var numbers = [1, 2, 3]; 
var val= numbers.entries(); 
console.log([...val]);

The following output is displayed on successful execution of the above code.

[[0,1],[1,2],[2,3]]

Array.from

Array.from() enables the creation of a new array from an array like object. The basic functionality of Array.from() is to convert two kinds of values to Arrays −

  • Array-like values.

  • Iterable values like Set and Map.

Example

"use strict" 
for (let i of Array.from('hello')) { 
   console.log(i) 
}

The following output is displayed on successful execution of the above code.

h                               
e                               
l                               
l                               
o

Array.prototype.keys()

This function returns the array indexes.

Example

console.log(Array.from(['a', 'b'].keys()))

The following output is displayed on successful execution of the above code.

[ 0, 1 ]

Array Traversal using for…in loop

One can use the for… in loop to traverse through an array.

"use strict" 
var nums = [1001,1002,1003,1004] 
for(let j in nums) { 
   console.log(nums[j]) 
}

The loop performs an index-based array traversal. The following output is displayed on successful execution of the above code.

1001 
1002 
1003 
1004

Arrays in JavaScript

JavaScript supports the following concepts about Arrays −

Sr.No Concept & Description
1 Multi-dimensional arrays

JavaScript supports multidimensional arrays. The simplest form of the multidimensional array is the two-dimensional array

2 Passing arrays to functions

You can pass to the function a pointer to an array by specifying the array's name without an index.

3 Return array from functions

Allows a function to return an array.

Array De-structuring

Destructuring refers to extracting individual values from an array or an object into distinct variables. Consider a scenario where the values of an array need to be assigned to individual variables. The traditional way of doing this is given below −

var a= array1[0]
var b= array1[1]
var c= array1[2]

Destructuring helps to achieve the same in a concise way.

Syntax

//destructuring an array
let [variable1,variable2]=[item1,item2]
//destructuring an object
let {property1,property2} = {property1:value1,property2:value2}

Example

<script>
   let names = ['Mohtashim','Kannan','Kiran']
   let [n1,n2,n3] = names;
   console.log(n1)
   console.log(n2)
   console.log(n3);
   //rest operator with array destructuring
   let locations=['Mumbai','Hyderabad','Chennai']
   let [l1,...otherValues] =locations
   console.log(l1)
   console.log(otherValues)
   //variables already declared
   let name1,name2;
   [name1,name2] =names
   console.log(name1)
   console.log(name2)
   //swapping
   let first=10,second=20;
   [second,first] = [first,second]
   console.log("second is ",second) //10
   console.log("first is ",first) //20
</script>

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

Mohtashim
Kannan
Kiran
Mumbai
["Hyderabad", "Chennai"]
Mohtashim
Kannan
second is 10
first is 20

The Date object is a datatype built into the JavaScript language. Date objects are created with the new Date () as shown in the following syntax.

Once a Date object is created, a number of methods allow you to operate on it. Most methods simply allow you to get and set the year, month, day, hour, minute, second, and millisecond fields of the object, using either local time or UTC (universal, or GMT) time.

The ECMAScript standard requires the Date object to be able to represent any date and time, to millisecond precision, within 100 million days before or after 1/1/1970. This is a range of plus or minus 273,785 years, so JavaScript can represent date and time till the year 275755.

You can use any of the following syntax to create a Date object using Date () constructor.

new Date( ) 
new Date(milliseconds) 
new Date(datestring) 
new Date(year,month,date[,hour,minute,second,millisecond ])

Note − Parameters in the brackets are always optional.

Date Properties

Here is a list of the properties of the Date object along with their description.

Sr.No Property & Description
1 constructor

Specifies the function that creates an object's prototype

2 prototype

The prototype property allows you to add properties and methods to an object

Date Methods

Following is a list of different date methods along with the description.

Sr.No Method & Description
1 Date()

Returns today's date and time

2 getDate()

Returns the day of the month for the specified date according to the local time

3 getDay()

Returns the day of the week for the specified date according to the local time

4 getFullYear()

Returns the year of the specified date according to the local time

5 getHours()

Returns the hour in the specified date according to the local time

6 getMilliseconds()

Returns the milliseconds in the specified date according to the local time

7 getMinutes()

Returns the minutes in the specified date according to the local time

8 getMonth()

Returns the month in the specified date according to the local time

9 getSeconds()

Returns the seconds in the specified date according to the local time

10 getTime()

Returns the numeric value of the specified date as the number of milliseconds since January 1, 1970, 00:00:00 UTC

11 getTimezoneOffset()

Returns the time-zone offset in minutes for the current locale

12 getUTCDate()

Returns the day (date) of the month in the specified date according to the universal time

13 getUTCDay()

Returns the day of the week in the specified date according to the universal time

14 getUTCFullYear()

Returns the year in the specified date according to the universal time

15 getutcHours()

Returns the hours in the specified date according to the universal time

16 getUTCMilliseconds()

Returns the milliseconds in the specified date according to the universal time

17 getUTCMinutes()

Returns the minutes in the specified date according to the universal time

18 getUTCMonth()

Returns the month in the specified date according to the universal time

19 getUTCSeconds()

Returns the seconds in the specified date according to the universal time

20 setDate()

Sets the day of the month for a specified date according to the local time

21 setFullYear()

Sets the full year for a specified date according to the local time

22 setHours()

Sets the hours for a specified date according to the local time

23 setMilliseconds()

Sets the milliseconds for a specified date according to the local time

24 setMinutes()

Sets the minutes for a specified date according to the local time

25 setMonth()

Sets the month for a specified date according to the local time

26 setSeconds()

Sets the seconds for a specified date according to the local time

27 setTime()

Sets the Date object to the time represented by a number of milliseconds since January 1, 1970, 00:00:00 UTC

28 setUTCDate()

Sets the Date object to the time represented by a number of milliseconds since January 1, 1970, 00:00:00 UTC

29 setUTCFullYear()

Sets the full year for a specified date according to the universal time

30 setUTCHours()

Sets the hour for a specified date according to the universal time

31 setUTCMilliseconds()

Sets the milliseconds for a specified date according to the universal time

32 setUTCMinutes()

Sets the minutes for a specified date according to the universal time

33 setUTCMonth()

Sets the month for a specified date according to the universal time

34 setUTCSeconds()

Sets the seconds for a specified date according to the universal time

35 todatestring()

Returns the "date" portion of the Date as a human-readable string

36 toLocaleDateString()

Returns the "date" portion of the Date as a string, using the current locale's conventions

37 toLocaleString()

Converts a date to a string, using the current locale's conventions

38 toLocaleTimeString()

Returns the "time" portion of the Date as a string, using the current locale's conventions

39 toString()

Returns a string representing the specified Date object

40 toTimeString()

Returns the "time" portion of the Date as a human-readable string

41 toUTCString()

Converts a date to a string, using the universal time convention

42 valueOf()

Returns the primitive value of a Date object

गणित की वस्तु आपको गणितीय स्थिरांक और कार्यों के लिए गुण और विधियाँ प्रदान करती है। अन्य वैश्विक वस्तुओं के विपरीत,Mathकंस्ट्रक्टर नहीं है। मठ के सभी गुण और विधियाँ स्थिर हैं और इसे बनाये बिना एक वस्तु के रूप में मठ का उपयोग करके बुलाया जा सकता है।

मठ के गुण

निम्नलिखित सभी मठ गुणों और उसके विवरण की एक सूची है।

अनु क्रमांक संपत्ति विवरण
1

यूलर का स्थिर और प्राकृतिक लघुगणक का आधार, लगभग 2.718

2 LN2

2 का प्राकृतिक लघुगणक, लगभग 0.693

3 LN10

10 का प्राकृतिक लघुगणक, लगभग 2.302

4 LOG2E

ई का आधार 2 लघुगणक, लगभग 1.442

5 LOG10E

ई का आधार 10 लघुगणक, लगभग 0.434

6 अनुकरणीय

इसके व्यास के एक वृत्त की परिधि का अनुपात, लगभग 3.14159

7 SQRT1_2

1/2 की वर्गमूल; समान रूप से, 2 के वर्गमूल पर 1, लगभग 0.707

8 SQRT2

2 का वर्गमूल, लगभग 1.414

घातीय कार्य

मूल घातीय कार्य है Math.pow(), और निम्न तालिका में दिखाए गए अनुसार वर्गमूल, घनमूल और ई की शक्तियों के लिए सुविधा कार्य हैं।

अनु क्रमांक समारोह विवरण
1 गणित। Pow (x, y)

रिटर्न x सत्ता के लिए उठाया y

2 Math.sqrt (एक्स)

संख्या का वर्गमूल देता है x

3 Math.cbrt (एक्स)

यह विधि किसी संख्या का घनमूल लौटाती है x

4 Math.exp (एक्स)

Math.pow (Math.E, x) के बराबर

5 Math.expm1 (एक्स)

Math.exp (x) के बराबर - 1

6 Math.hypot (X1, x2, ...)

तर्कों के योग का वर्गमूल देता है

लघुगणक कार्य

मूल प्राकृतिक लघुगणक कार्य है Math.log ()। जावास्क्रिप्ट में, "लॉग" का अर्थ है "प्राकृतिक लघुगणक।" ES6 ने सुविधा के लिए Math.log10 की शुरुआत की।

अनु क्रमांक समारोह विवरण
1 Math.log (एक्स)

का प्राकृतिक लघुगणक x

2 Math.log10 (एक्स)

बेस 10 का लघुगणक x

3 Math.log2 (एक्स)

बेस 2 का लघुगणक x

4 Math.log1p (एक्स)

का प्राकृतिक लघुगणक 1 + x

विविध बीजगणितीय कार्य

निम्नलिखित उनके विवरण के साथ विविध बीजीय कार्यों की एक सूची है।

अनु क्रमांक समारोह विवरण
1 Math.abs (एक्स)

X का पूर्ण मान

2 Math.sign (एक्स)

X का चिन्ह: यदि x ऋणात्मक है, तो -1; यदि x धनात्मक है, 1; और यदि x 0, 0 है

3 Math.ceil (एक्स)

X की छत: x से अधिक या बराबर सबसे छोटा पूर्णांक

4 Math.floor (एक्स)

X का तल: x से कम या बराबर सबसे बड़ा पूर्णांक है

5 Math.trunc (एक्स)

एक्स का अभिन्न अंग (सभी आंशिक अंक हटा दिए जाते हैं)

6 गणित.गोल (एक्स)

x निकटतम पूर्णांक तक गोल है

7 Math.min (X1, x2, ...)

न्यूनतम तर्क देता है

8 Math.max (X1, x2, ...)

न्यूनतम तर्क देता है

त्रिकोणमितीय फलन

मैथ लाइब्रेरी में सभी त्रिकोणमितीय फ़ंक्शन रेडियन पर संचालित होते हैं, डिग्री नहीं।

अनु क्रमांक समारोह विवरण
1 गणित.पाप (एक्स)

एक्स रेडियंस की साइन

2 गणित.क्योंकि (एक्स)

एक्स रेडियंस के कोसाइन

3 Math.tan (एक्स)

एक्स रेडियंस की स्पर्शरेखा

4 Math.asin (एक्स)

एक्स के विपरीत साइन (आर्क्सिन) (रेडियन में परिणाम)

5 Math.acos (एक्स)

एक्स का कोसाइन (अरकोस) (परिणाम रेडियंस में)

6 Math.atan (एक्स)

एक्स का उलटा स्पर्श (arctan) (रेडियन में परिणाम)

7 Math.atan2 (y, x0)

एक्स-अक्ष से बिंदु (x, y) तक वामावर्त कोण (रेडियन में)

Math.random ()

Math.random() फ़ंक्शन 0 (समावेशी) और 1 (अनन्य) के बीच एक छद्म आयामी संख्या देता है।

उदाहरण: छद्म आयामी संख्या पीढ़ी (PRNG)

var value1 = Math.random();  
console.log("First Test Value : " + value1 ); 

var value2 = Math.random();  
console.log("Second Test Value : " + value2 ); 

var value3 = Math.random();  
console.log("Third Test Value : " + value3 ); 

var value4 = Math.random(); 
console.log("Fourth Test Value : " + value4 );

उत्पादन

First Test Value : 0.5782922627404332 
Second Test Value : 0.5624510529451072 
Third Test Value : 0.9336334094405174 
Fourth Test Value : 0.4002739654388279

एक नियमित अभिव्यक्ति एक ऐसी वस्तु है जो वर्णों के पैटर्न का वर्णन करती है। नियमित अभिव्यक्तियाँ अक्सर संक्षिप्त होती हैं ”regex""regexp"।

जावास्क्रिप्ट RegExp कक्षा नियमित अभिव्यक्तियों का प्रतिनिधित्व करती है, और स्ट्रिंग और RegExp दोनों तरीकों को परिभाषित करते हैं जो पाठ पर शक्तिशाली पैटर्न-मिलान और खोज-और-कार्य को बदलने के लिए नियमित अभिव्यक्ति का उपयोग करते हैं।

एक नियमित अभिव्यक्ति के रूप में परिभाषित किया जा सकता है -

var pattern = new RegExp(pattern, attributes); 
OR 
var pattern = /pattern/attributes;

विशेषता में निम्न मानों का कोई भी संयोजन हो सकता है।

अनु क्रमांक विशेषता और विवरण
1

G

ग्लोबल मैच

2

I

मामले की अनदेखी करें

3

M

बहुपंक्ति; शुरुआत और समाप्ति वर्ण (^ और $) को कई लाइनों पर काम करने के रूप में समझें (यानी, प्रत्येक पंक्ति की शुरुआत या अंत से मेल खाते हैं (सीमांकित द्वारा \ n या \ r), न केवल पूरे इनपुट स्ट्रिंग की बहुत शुरुआत या अंत )

4

U

यूनिकोड; यूनिकोड कोड बिंदुओं के अनुक्रम के रूप में पैटर्न का इलाज करें

5

Y

चिपचिपा; केवल लक्ष्य स्ट्रिंग में इस नियमित अभिव्यक्ति के अंतिम गुण द्वारा इंगित सूचकांक से मेल खाता है (और किसी भी बाद के सूचकांक से मिलान करने का प्रयास नहीं करता है)

नियमित अभिव्यक्ति का निर्माण

कोष्ठक

नियमित अभिव्यक्तियों के संदर्भ में उपयोग किए जाने पर ब्रैकेट ([]) का एक विशेष अर्थ है। उनका उपयोग वर्णों की श्रेणी खोजने के लिए किया जाता है।

अनु क्रमांक अभिव्यक्ति और विवरण
1

[...]

कोष्ठक के बीच कोई एक वर्ण

2

[^...]

कोई एक वर्ण कोष्ठक के बीच नहीं

3

[0-9]

यह 0 से 9 तक किसी भी दशमलव अंक से मेल खाता है

4

[a-z]

यह लोअरकेस से किसी भी वर्ण से मेल खाता है a लोअरकेस के माध्यम से z

5

[A-Z]

यह अपरकेस से किसी भी चरित्र से मेल खाता है A अपरकेस जेड के माध्यम से

6

[a-Z]

यह लोअरकेस से किसी भी वर्ण से मेल खाता है a अपरकेस जेड के माध्यम से

ऊपर दिखाई गई श्रेणियां सामान्य हैं; आप किसी भी दशमलव अंक को 0 से 3 के माध्यम से मिलान करने के लिए [0-3] की सीमा का उपयोग कर सकते हैं, या किसी भी लोअरकेस वर्ण को v से b से लेकर श्रेणी से मिलान करने के लिए [bv] श्रेणी का उपयोग कर सकते हैं।

परिमाणकों

ब्रैकेटेड वर्ण अनुक्रमों और एकल वर्णों की आवृत्ति या स्थिति को एक विशेष वर्ण द्वारा निरूपित किया जा सकता है। प्रत्येक विशेष चरित्र का एक विशिष्ट अर्थ है। +, *, ?, तथा $ झंडे सभी एक चरित्र अनुक्रम का पालन करते हैं।

अनु क्रमांक अभिव्यक्ति और विवरण
1

p+

यह कम से कम एक युक्त किसी भी तार से मेल खाता है p

2

p*

यह शून्य या अधिक वाले किसी भी तार से मेल खाता है p's

3

p?

यह एक या अधिक से युक्त किसी भी तार से मेल खाता है p's

4

p{N}

यह किसी भी तार से मेल खाता है जिसमें एक अनुक्रम है N p's

5

p{2,3}

यह दो या तीन के अनुक्रम वाले किसी भी तार से मेल खाता है p's

6

p{2, }

यह किसी भी तार से मेल खाता है जिसमें कम से कम दो का अनुक्रम होता है p's

7

p$

यह किसी भी स्ट्रिंग के साथ मेल खाता है p इसके अंत में

8

^p

यह किसी भी स्ट्रिंग के साथ मेल खाता है p इसकी शुरुआत में

9

[^a-zA-Z]

यह किसी भी स्ट्रिंग से मेल खाता है जिसमें से कोई भी वर्ण नहीं है a के माध्यम से z तथा A के माध्यम से Z

10

p.p

यह किसी भी स्ट्रिंग से मेल खाता है p, किसी भी चरित्र के बाद, बदले में दूसरे द्वारा पीछा किया जाता है p

1 1

^.{2}$

यह किसी भी तार से मेल खाता है जिसमें दो अक्षर हैं

12

<b>(.*)</b>

यह <b> और </ b> के भीतर संलग्न किसी भी स्ट्रिंग से मेल खाता है

13

p(hp)*

यह किसी भी स्ट्रिंग से मेल खाता है p अनुक्रम के शून्य या अधिक उदाहरणों के बाद hp

शाब्दिक वर्ण

अनु क्रमांक चरित्र विवरण, चारित्रिक व्यौरा, वर्णन, व्याख्या
1

Alphanumeric

अपने आप

2

\0

पूरा चरित्र (\ u0000)

3

\t

टैब (\ u0009)

4

\n

न्यूलाइन (\ u000A)

5

\v

कार्यक्षेत्र टैब (\ u000B)

6

\f

फॉर्म फ़ीड (\ u000C)

7

\r

गाड़ी वापसी (\ u000D)

8

\xnn

हेक्साडेसिमल संख्या द्वारा निर्दिष्ट लैटिन वर्ण nn; उदाहरण के लिए, \ x0A समान है \n

9

\uxxxx

हेक्साडेसिमल संख्या द्वारा निर्दिष्ट यूनिकोड वर्ण xxxx; उदाहरण के लिए, \ u0009 के रूप में ही है\t

10

\cX

नियंत्रण चरित्र ^ एक्स; उदाहरण के लिए, \ cJ newline वर्ण के बराबर है\n

मेटा-वर्ण

meta-character बस एक वर्णमाला वर्ण है जो एक बैकस्लैश से पहले था जो संयोजन को एक विशेष अर्थ देने के लिए कार्य करता है।

उदाहरण के लिए, आप एक बड़ी राशि का उपयोग करके खोज सकते हैं '\d'मेटा-चरित्र: / ([\ d] +) 000 /। यहाँ,\d संख्यात्मक चरित्र के किसी भी स्ट्रिंग के लिए खोज करेंगे।

निम्न तालिका मेटा-पात्रों के एक सेट को सूचीबद्ध करती है जो कि पेरल स्टाइल रेगुलर एक्सप्रेशंस में उपयोग किए जा सकते हैं।

अनु क्रमांक चरित्र विवरण, चारित्रिक व्यौरा, वर्णन, व्याख्या
1

.

एक एकल चरित्र

2

\s

एक व्हाट्सएप कैरेक्टर (स्पेस, टैब, न्यूलाइन)

3

\S

गैर-व्हाट्सएप चरित्र

4

\d

एक अंक (0-9)

5

\D

एक गैर अंक

6

\w

एक शब्द चरित्र (az, AZ, 0-9, _)

7

\W

एक गैर-शब्द चरित्र

8

[\b]

एक शाब्दिक बैकस्पेस (विशेष मामला)

9

[aeiou]

दिए गए सेट में एकल वर्ण से मेल खाता है

10

[^aeiou]

दिए गए सेट के बाहर एक एकल वर्ण से मेल खाता है

1 1

(foo|bar|baz)

निर्दिष्ट विकल्पों में से किसी से मेल खाता है

RegExp गुण

अनु क्रमांक गुण और विवरण
1 RegExp.prototype.flags

एक स्ट्रिंग जिसमें RegExp ऑब्जेक्ट के झंडे होते हैं

2 RegExp.prototype.global

चाहे एक स्ट्रिंग में सभी संभावित मैचों के खिलाफ नियमित अभिव्यक्ति का परीक्षण करना है, या केवल पहले के खिलाफ है

3 RegExp.prototype.ignoreCase

एक स्ट्रिंग में मैच का प्रयास करते समय मामले को अनदेखा करना है या नहीं

4 RegExp.prototype.lastIndex

चाहे RegExp ऑब्जेक्ट्स की संपत्ति पढ़ें / लिखें।

5 RegExp.prototype.multiline

कई लाइनों में तार खोजने के लिए या नहीं

6 RegExp.prototype.source

पैटर्न का पाठ

RegExp तरीके

अनु क्रमांक विधि और विवरण
1 RegExp.prototype.exec ()

अपने स्ट्रिंग पैरामीटर में एक मैच की खोज को निष्पादित करता है

2 RegExp.prototype.test ()

इसके स्ट्रिंग पैरामीटर में एक मैच के लिए टेस्ट

3 RegExp.prototype.match ()

दिए गए स्ट्रिंग के लिए एक मैच करता है और मैच परिणाम देता है

4 RegExp.prototype.replace ()

दिए गए स्ट्रिंग में एक नए विकल्प के साथ मेल खाता है

5 RegExp.prototype.search ()

दिए गए स्ट्रिंग में मैच खोजता है और इंडेक्स को स्ट्रिंग में पाया गया पैटर्न लौटाता है

6 RegExp.prototype.split ()

स्ट्रिंग में सबस्ट्रिंग को अलग करके दिए गए स्ट्रिंग को एक ऐरे में विभाजित करता है

7 RegExp.prototype.toString ()

निर्दिष्ट ऑब्जेक्ट का प्रतिनिधित्व करने वाला स्ट्रिंग लौटाता है। ओवरराइड्स TheObject.prototype.toString () विधि

हर वेब पेज एक ब्राउज़र विंडो के अंदर रहता है, जिसे एक ऑब्जेक्ट माना जा सकता है।

document objectउस विंडो में प्रदर्शित HTML दस्तावेज़ का प्रतिनिधित्व करता है। दस्तावेज़ ऑब्जेक्ट में विभिन्न गुण होते हैं जो अन्य वस्तुओं को संदर्भित करते हैं जो दस्तावेज़ सामग्री तक पहुंच और संशोधन की अनुमति देते हैं।

जिस तरह से एक दस्तावेज़ सामग्री तक पहुँचा और संशोधित किया जाता है उसे कहा जाता है Document Object Model, या DOM। वस्तुओं को एक पदानुक्रम में व्यवस्थित किया जाता है। यह पदानुक्रमित संरचना एक वेब दस्तावेज़ में वस्तुओं के संगठन पर लागू होती है।

निम्नलिखित कुछ महत्वपूर्ण वस्तुओं का एक सरल पदानुक्रम है -

अस्तित्व में कई DOM हैं। निम्नलिखित अनुभाग इन डोमों में से प्रत्येक को विस्तार से बताते हैं और वर्णन करते हैं कि आप दस्तावेज़ सामग्री तक पहुंचने और संशोधित करने के लिए उनका उपयोग कैसे कर सकते हैं।

  • The Legacy DOM- यह वह मॉडल है जिसे जावास्क्रिप्ट भाषा के शुरुआती संस्करणों में पेश किया गया था। यह सभी ब्राउज़रों द्वारा अच्छी तरह से समर्थित है, लेकिन दस्तावेज़ों के कुछ प्रमुख भागों, जैसे कि फ़ॉर्म, फॉर्म एलिमेंट्स, और छवियों तक ही पहुँच प्रदान करता है।

  • The W3C DOM- यह डॉक्यूमेंट ऑब्जेक्ट मॉडल सभी डॉक्यूमेंट कंटेंट के एक्सेस और संशोधन की अनुमति देता है और वर्ल्ड वाइड वेब कंसोर्टियम (W3C) द्वारा मानकीकृत है। यह मॉडल लगभग सभी आधुनिक ब्राउज़रों द्वारा समर्थित है।

  • The IE4 DOM- यह दस्तावेज़ ऑब्जेक्ट मॉडल Microsoft के इंटरनेट एक्सप्लोरर ब्राउज़र के संस्करण 4 में पेश किया गया था। IE 5 और बाद के संस्करणों में अधिकांश बुनियादी W3C DOM सुविधाओं के लिए समर्थन शामिल है।

विरासत डोम

यह वह मॉडल है जिसे जावास्क्रिप्ट भाषा के शुरुआती संस्करणों में पेश किया गया था। यह सभी ब्राउज़रों द्वारा अच्छी तरह से समर्थित है, लेकिन केवल दस्तावेजों के कुछ प्रमुख भागों तक ही पहुँच प्रदान करता है, जैसे कि प्रपत्र, प्रपत्र तत्व और चित्र।

यह मॉडल कई रीड-ओनली गुण प्रदान करता है, जैसे शीर्षक, URL, और अंतिम रूप में दस्तावेज़ के बारे में संपूर्ण जानकारी प्रदान करता है। इसके अलावा, इस मॉडल द्वारा प्रदान किए गए विभिन्न तरीके हैं जो दस्तावेज़ संपत्ति मूल्यों को सेट और प्राप्त करने के लिए उपयोग किया जा सकता है।

विरासत डोम में दस्तावेज़ गुण

निम्नलिखित दस्तावेज़ गुणों की एक सूची है, जिसे लीगेसी डोम का उपयोग करके एक्सेस किया जा सकता है।

अनु क्रमांक संपत्ति विवरण
1

alinkColor

पदावनत - एक स्ट्रिंग जो सक्रिय लिंक के रंग को निर्दिष्ट करती है।

Example : document.alinkColor

2

anchors[ ]

एंकर ऑब्जेक्ट्स की एक सरणी, दस्तावेज़ में दिखाई देने वाले प्रत्येक एंकर के लिए एक।

Example : document.anchors [0], document.anchors [1] और इसी तरह

3

applets[ ]

दस्तावेज़ में दिखाई देने वाले प्रत्येक एपलेट के लिए एक एपलेट ऑब्जेक्ट की एक सरणी।

Example : document.applets [0], document.applets [1] और इसी तरह

4

bgColor

पदावनत - एक स्ट्रिंग जो दस्तावेज़ की पृष्ठभूमि का रंग निर्दिष्ट करती है।

Example : document.bgColor

5

Cookie

विशेष व्यवहार के साथ एक स्ट्रिंग मूल्यवान संपत्ति जो इस दस्तावेज़ से जुड़े कुकीज़ को क्वियर और सेट करने की अनुमति देती है।

Example : document.cookie

6

Domain

एक स्ट्रिंग जो इंटरनेट डोमेन को निर्दिष्ट करता है वह दस्तावेज़ है। सुरक्षा उद्देश्यों के लिए उपयोग किया जाता है।

Example : document.domain

7

embeds[ ]

ऑब्जेक्ट की एक सरणी जो दस्तावेज़ में एम्बेड किए गए डेटा को <एम्बेड> टैग के साथ दर्शाती है। प्लगइन्स का एक पर्याय []। कुछ प्लगइन्स और ActiveX नियंत्रण जावास्क्रिप्ट कोड के साथ नियंत्रित किए जा सकते हैं।

Example : document.embeds [0], document.embeds [1] और इसी तरह

8

fgColor

एक स्ट्रिंग जो दस्तावेज़ के लिए डिफ़ॉल्ट पाठ रंग निर्दिष्ट करती है।

Example : document.fgColor

9

forms[ ]

प्रपत्र ऑब्जेक्ट्स की एक सरणी, दस्तावेज़ में दिखाई देने वाले प्रत्येक HTML फॉर्म के लिए।

Example : document.forms [0], document.forms [1] और इसी तरह

10

images[ ]

प्रपत्र ऑब्जेक्ट्स की एक सरणी, प्रत्येक HTML फ़ॉर्म के लिए एक जो HTML <img> टैग के साथ दस्तावेज़ में दिखाई देता है।

Example : document.forms[0], document.forms[1] and so on

11

lastModified

A read-only string that specifies the date of the most recent change to the document.

Example : document.lastModified

12

linkColor

Deprecated − A string that specifies the color of unvisited links.

Example : document.linkColor

13

links[ ]

It is a document link array.

Example : document.links[0], document.links[1] and so on

14

Location

The URL of the document. Deprecated in favor of the URL property.

Example : document.location

15

plugins[ ]

A synonym for the embeds[ ]

Example : document.plugins[0], document.plugins[1] and so on

16

Referrer

A read-only string that contains the URL of the document, if any, from which the current document was linked.

Example : document.referrer

17

Title

The text contents of the <title> tag.

Example : document.title

18

URL

A read-only string that specifies the URL of the document.

Example : document.URL

19

vlinkColor

Deprecated − A string that specifies the color of the visited links.

Example : document.vlinkColor

Document Methods in Legacy DOM

Following is a list of methods supported by Legacy DOM.

Sr.No Property & Description
1

clear( )

Deprecated − Erases the contents of the document and returns nothing.

Example : document.clear( )

2

close( )

Closes a document stream opened with the open( ) method and returns nothing.

3

open( )

Deletes the existing document content and opens a stream to which the new document contents may be written. Returns nothing.

Example : document.open( )

4

write( value, ...)

Inserts the specified string or strings into the document currently being parsed or appends to the document opened with open( ). Returns nothing.

Example : document.write( value, ...)

5

writeln( value, ...)

Identical to write( ), except that it appends a newline character to the output. Returns nothing.

Example : document.writeln( value, ...)

We can locate any HTML element within any HTML document using HTML DOM. For instance, if a web document contains a form element, then using JavaScript, we can refer to it as document.forms[0]. If your Web document includes two form elements, the first form is referred to as document.forms[0] and the second as document.forms[1].

Using the hierarchy and properties given above, we can access the first form element using document.forms[0].elements[0] and so on.

Example

Following is an example to access document properties using Legacy DOM method.

<html> 
   <head> 
      <title> Document Title </title> 
      
      <script type = "text/javascript"> 
         <!--  
            function myFunc() {  
               var ret = document.title;  
               alert("Document Title : " + ret );  
               var ret = document.URL;  
               alert("Document URL : " + ret );  
               var ret = document.forms[0];  
               alert("Document First Form : " + ret );  
               var ret = document.forms[0].elements[1];  
               alert("Second element : " + ret );  
            } //
         --> 
      </script> 
   </head> 
   
   <body> 
      <h1 id = "title">This is main title</h1> 
      <p>Click the following to see the result:</p> 
      
      <form name = "FirstForm">
         <input type = "button" value = "Click Me" onclick = "myFunc();" /> 
         <input type = "button" value = "Cancel"> 
      </form> 

      <form name = "SecondForm"> 
         <input type = "button" value = "Don't ClickMe"/> 
      </form> 
   </body> 
   
</html>

Output

The following output is displayed on successful execution of the above code.

Note − This example returns the objects for forms and elements. We would have to access their values by using those object properties which are not discussed in this tutorial.

Introduction to Iterator

Iterator is an object which allows us to access a collection of objects one at a time.

The following built-in types are by default iterable −

  • String
  • Array
  • Map
  • Set

An object is considered iterable, if the object implements a function whose key is [Symbol.iterator] and returns an iterator. A for...of loop can be used to iterate a collection.

Example

The following example declares an array, marks, and iterates through it by using a for..of loop.

<script>
   let marks = [10,20,30]
   //check iterable using for..of
   for(let m of marks){
      console.log(m);
   }
</script>

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

10
20
30

Example

The following example declares an array, marks and retrieves an iterator object. The [Symbol.iterator]() can be used to retrieve an iterator object. The next() method of the iterator returns an object with 'value' and 'done' properties . 'done' is Boolean and returns true after reading all items in the collection.

<script>
   let marks = [10,20,30]
   let iter = marks[Symbol.iterator]();
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
</script>

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

{value: 10, done: false}
{value: 20, done: false}
{value: 30, done: false}
{value: undefined, done: true}

Custom Iterable

Certain types in JavaScript are iterable (E.g. Array, Map etc.) while others are not (E.g. Class). JavaScript types which are not iterable by default can be iterated by using the iterable protocol.

The following example defines a class named CustomerList which stores multiple customer objects as an array. Each customer object has firstName and lastName properties.

To make this class iterable, the class must implement [Symbol.iterator]() function. This function returns an iterator object. The iterator object has a function next which returns an object {value:'customer',done:true/false}.

<script>
   //user defined iterable
   class CustomerList {
      constructor(customers){
         //adding customer objects to an array
         this.customers = [].concat(customers)
      }
      //implement iterator function
      [Symbol.iterator](){
         let count=0;
         let customers = this.customers
         return {
            next:function(){
            //retrieving a customer object from the array
               let customerVal = customers[count];
               count+=1;
               if(count<=customers.length){
                  return {
                     value:customerVal,
                     done:false
                  }
               }
               //return true if all customer objects are iterated
               return {done:true}
            }
         }
      }
   }
   //create customer objects
   let c1={
      firstName:'Sachin',
      lastName:'Tendulkar'
   }
   let c2={
      firstName:'Rahul',
      lastName:'Dravid'
   }
   //define a customer array and initialize it let customers=[c1,c2]
   //pass customers to the class' constructor
   let customersObj = new CustomerList(customers);
   //iterating using for..of
   for(let c of customersObj){
      console.log(c)
   }
   //iterating using the next() method
   let iter = customersObj[Symbol.iterator]();
   console.log(iter.next())
   console.log(iter.next())
   console.log(iter.next())
</script>

The output of the above code will be as follows −

{firstName: "Sachin", lastName: "Tendulkar"}
{firstName: "Rahul", lastName: "Dravid"}
{
   done: false
   value: {
      firstName: "Sachin",
      lastName: "Tendulkar"
   }
}
{
   done: false
   value: {
      firstName: "Rahul",
      lastName: "Dravid"
   }
}
{done: true}

Generator

Prior to ES6, functions in JavaScript followed a run-to completion model. ES6 introduces functions known as Generator which can stop midway and then continue from where it stopped.

A generator prefixes the function name with an asterisk * character and contains one or more yield statements. The yield keyword returns an iterator object.

Syntax

function * generator_name() {
   yield value1
   ...
   yield valueN
}

Example

The example defines a generator function getMarks with three yield statements. Unlike normal functions, the generator function getMarks(),when invoked, doesn’t execute the function but returns an iterator object that helps you to execute code inside the generator function.

On the first call to markIter.next() operations in the beginning would run and the yield statement pauses the execution of the generator. Subsequent calls to the markIter.next() will resume the generator function until the next yield expression.

<script>
   //define generator function
   function * getMarks(){
      console.log("Step 1")
      yield 10
      console.log("Step 2")
      yield 20
      console.log("Step 3")
      yield 30
      console.log("End of function")
   }
   //return an iterator object
      let markIter = getMarks()
   //invoke statements until first yield
      console.log(markIter.next())
   //resume execution after the last yield until second yield expression
      console.log(markIter.next())
   //resume execution after last yield until third yield expression
      console.log(markIter.next())
      console.log(markIter.next()) // iteration is completed;no value is returned
</script>

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

Step 1
{value: 10, done: false}
Step 2
{value: 20, done: false}
Step 3
{value: 30, done: false}
End of function
{value: undefined, done: true}

Example

The following example creates an infinite sequence of even numbers through

* evenNumberGenerator generator function.

We can iterate through all even numbers by using next() or using for of loop as shown below

<script>
   function * evenNumberGenerator(){
      let num = 0;
      while(true){
         num+=2
         yield num
      }
   }
   // display first two elements
   let iter = evenNumberGenerator();
   console.log(iter.next())
   console.log(iter.next())
   //using for of to iterate till 12
   for(let n of evenNumberGenerator()){
      if(n==12)break;
      console.log(n);
   }
</script>

The output of the above code will be as follows −

{value: 2, done: false}
{value: 4, done: false}
2
4
6
8
10

ES6 introduces two new data structures: Maps and Sets.

  • Maps − This data structure enables mapping a key to a value.

  • Sets − Sets are similar to arrays. However, sets do not encourage duplicates.

Maps

The Map object is a simple key/value pair. Keys and values in a map may be primitive or objects.

Following is the syntax for the same.

new Map([iterable])

The parameter iterable represents any iterable object whose elements comprise of a key/value pair. Maps are ordered, i.e. they traverse the elements in the order of their insertion.

Map Properties

Sr.No Property & Description
1 Map.prototype.size

This property returns the number of key/value pairs in the Map object.

Understanding basic Map operations

The set() function sets the value for the key in the Map object. The set() function takes two parameters namely, the key and its value. This function returns the Map object.

The has() function returns a boolean value indicating whether the specified key is found in the Map object. This function takes a key as parameter.

var map = new Map(); 
map.set('name','Tutorial Point'); 
map.get('name'); // Tutorial point

The above example creates a map object. The map has only one element. The element key is denoted by name. The key is mapped to a value Tutorial point.

Note − Maps distinguish between similar values but bear different data types. In other words, an integer key 1 is considered different from a string key “1”. Consider the following example to better understand this concept

var map = new Map(); 
map.set(1,true); 
console.log(map.has("1")); //false 
map.set("1",true); 
console.log(map.has("1")); //true

Output

false 
true

The set() method is also chainable. Consider the following example.

var roles = new Map(); 
roles.set('r1', 'User') 
.set('r2', 'Guest') 
.set('r3', 'Admin'); 
console.log(roles.has('r1'))

Output

True

The above example, defines a map object. The example chains the set() function to define the key/value pair.

The get() function is used to retrieve the value corresponding to the specified key.

The Map constructor can also be passed an array. Moreover, map also supports the use of spread operator to represent an array.

Example

var roles = new Map([ 
   ['r1', 'User'], 
   ['r2', 'Guest'], 
   ['r3', 'Admin'], 
]);  
console.log(roles.get('r2'))

The following output is displayed on successful execution of the above code.

Guest

Note − The get() function returns undefined if the key specified doesn’t exist in the map.

The set() replaces the value for the key, if it already exists in the map. Consider the following example.

var roles = new Map([ 
   ['r1', 'User'], 
   ['r2', 'Guest'], 
   ['r3', 'Admin'], 
]);  
console.log(`value of key r1 before set(): ${roles.get('r1')}`) 
roles.set('r1','superUser') 
console.log(`value of key r1 after set(): ${roles.get('r1')}`)

The following output is displayed on successful execution of the above code.

value of key r1 before set(): User 
value of key r1 after set(): superUser

Map Methods

Sr.No Method & Description
1 Map.prototype.clear()

Removes all key/value pairs from the Map object.

2 Map.prototype.delete(key)

Removes any value associated to the key and returns the value that Map.prototype.has(key) would have previously returned.

Map.prototype.has(key) will return false afterwards.

3 Map.prototype.entries()

Returns a new Iterator object that contains an array of [key, value] for each element in the Map object in insertion order.

4 Map.prototype.forEach(callbackFn[, thisArg])

Calls callbackFn once for each key-value pair present in the Map object, in insertion order. If a thisArg parameter is provided to forEach, it will be used as the ‘this’ value for each callback .

5 Map.prototype.keys()

Returns a new Iterator object that contains the keys for each element in the Map object in insertion order.

6 Map.prototype.values()

Returns a new Iterator object that contains an array of [key, value] for each element in the Map object in insertion order.

The for…of Loop

The following example illustrates traversing a map using the for…of loop.

'use strict' 
var roles = new Map([ 
   ['r1', 'User'], 
   ['r2', 'Guest'], 
   ['r3', 'Admin'], 
]);
for(let r of roles.entries()) 
console.log(`${r[0]}: ${r[1]}`);

The following output is displayed on successful execution of the above code.

r1: User 
r2: Guest 
r3: Admin

Weak Maps

A weak map is identical to a map with the following exceptions −

  • Its keys must be objects.

  • Keys in a weak map can be Garbage collected. Garbage collection is a process of clearing the memory occupied by unreferenced objects in a program.

  • A weak map cannot be iterated or cleared.

Example : Weak Map

'use strict' 
let weakMap = new WeakMap(); 
let obj = {}; 
console.log(weakMap.set(obj,"hello"));  
console.log(weakMap.has(obj));// true

The following output is displayed on successful execution of the above code.

WeakMap {} 
true

Sets

A set is an ES6 data structure. It is similar to an array with an exception that it cannot contain duplicates. In other words, it lets you store unique values. Sets support both primitive values and object references.

Just like maps, sets are also ordered, i.e. elements are iterated in their insertion order. A set can be initialized using the following syntax.

Set Properties

Sr.No Property & Description
1 Set.prototype.size

Returns the number of values in the Set object.

Set Methods

Sr.No Method & Description
1 Set.prototype.add(value)

Appends a new element with the given value to the Set object. Returns the Set object.

2 Set.prototype.clear()

Removes all the elements from the Set object.

3 Set.prototype.delete(value)

Removes the element associated to the value.

4 Set.prototype.entries()

Returns a new Iterator object that contains an array of [value, value] for each element in the Set object, in insertion order. This is kept similar to the Map object, so that each entry has the same value for its key and value here.

5 Set.prototype.forEach(callbackFn[, thisArg])

Calls callbackFn once for each value present in the Set object, in insertion order. If athisArg parameter is provided to forEach, it will be used as the ‘this’ value for each callback.

6 Set.prototype.has(value)

Returns a boolean asserting whether an element is present with the given value in the Set object or not.

7 Set.prototype.values()

Returns a new Iterator object that contains the values for each element in the Set object in insertion order.

Weak Set

Weak sets can only contain objects, and the objects they contain may be garbage collected. Like weak maps, weak sets cannot be iterated.

Example: Using a Weak Set

'use strict' 
   let weakSet = new WeakSet();  
   let obj = {msg:"hello"}; 
   weakSet.add(obj); 
   console.log(weakSet.has(obj)); 
   weakSet.delete(obj); 
   console.log(weakSet.has(obj));

The following output is displayed on successful execution of the above code.

true 
false

Iterator

Iterator is an object which allows to access a collection of objects one at a time. Both set and map have methods which returns an iterator.

Iterators are objects with next() method. When next() method is invoked, it returns an object with 'value' and 'done' properties . 'done' is boolean, this will return true after reading all items in the collection

Example 1: Set and Iterator

var  set = new Set(['a','b','c','d','e']);  
var iterator = set.entries(); 
console.log(iterator.next())

The following output is displayed on successful execution of the above code.

{ value: [ 'a', 'a' ], done: false }

Since, the set does not store key/value, the value array contains similar key and value. done will be false as there are more elements to be read.

Example 2: Set and Iterator

var  set = new Set(['a','b','c','d','e']);  
var iterator = set.values(); 
console.log(iterator.next());

The following output is displayed on successful execution of the above code.

{ value: 'a', done: false }

Example 3: Set and Iterator

var  set = new Set(['a','b','c','d','e']);  
var iterator = set.keys(); 
console.log(iterator.next());

The following output is displayed on successful execution of the above code.

{ value: 'a', done: false }

Example 4: Map and Iterator

var map = new Map([[1,'one'],[2,'two'],[3,'three']]); 
var iterator = map.entries(); 
console.log(iterator.next());

The following output is displayed on successful execution of the above code.

{ value: [ 1, 'one' ], done: false }

Example 5: Map and Iterator

var map = new Map([[1,'one'],[2,'two'],[3,'three']]); 
var iterator = map.values(); 
console.log(iterator.next());

The following output is displayed on successful execution of the above code.

{value: "one", done: false}

Example 6: Map and Iterator

var map = new Map([[1,'one'],[2,'two'],[3,'three']]); 
var iterator = map.keys(); 
console.log(iterator.next());

The following output is displayed on successful execution of the above code.

{value: 1, done: false}

Object Orientation is a software development paradigm that follows real-world modelling. Object Orientation, considers a program as a collection of objects that communicates with each other via mechanism called methods. ES6 supports these object-oriented components too.

Object-Oriented Programming Concepts

To begin with, let us understand

  • Object − An object is a real-time representation of any entity. According to Grady Brooch, every object is said to have 3 features −

    • State − Described by the attributes of an object.

    • Behavior − Describes how the object will act.

    • Identity − A unique value that distinguishes an object from a set of similar such objects.

  • Class − A class in terms of OOP is a blueprint for creating objects. A class encapsulates data for the object.

  • Method − Methods facilitate communication between objects.

Let us translate these Object-Oriented concepts to the ones in the real world. For example: A car is an object that has data (make, model, number of doors, Vehicle Number, etc.) and functionality (accelerate, shift, open doors, turn on headlights, etc.)

Prior to ES6, creating a class was a fussy affair. Classes can be created using the class keyword in ES6.

Classes can be included in the code either by declaring them or by using class expressions.

Syntax: Declaring a Class

class Class_name {  
}

Syntax: Class Expressions

var var_name = new Class_name {  
}

The class keyword is followed by the class name. The rules for identifiers (already discussed) must be considered while naming a class.

A class definition can include the following −

  • Constructors − Responsible for allocating memory for the objects of the class.

  • Functions − Functions represent actions an object can take. They are also at times referred to as methods.

These components put together are termed as the data members of the class.

Note − A class body can only contain methods, but not data properties.

Example: Declaring a class

class Polygon { 
   constructor(height, width) { 
      this.height = height; 
      this.width = width; 
   } 
}

Example: Class Expression

var Polygon = class { 
   constructor(height, width) { 
      this.height = height; 
      this.width = width; 
   } 
}

The above code snippet represents an unnamed class expression. A named class expression can be written as.

var Polygon = class Polygon { 
   constructor(height, width) { 
      this.height = height; 
      this.width = width; 
   } 
}

Note − Unlike variables and functions, classes cannot be hoisted.

Creating Objects

To create an instance of the class, use the new keyword followed by the class name. Following is the syntax for the same.

var object_name= new class_name([ arguments ])

Where,

  • The new keyword is responsible for instantiation.

  • The right hand side of the expression invokes the constructor. The constructor should be passed values if it is parameterized.

Example: Instantiating a class

var obj = new Polygon(10,12)

Accessing Functions

A class’s attributes and functions can be accessed through the object. Use the ‘.’ dot notation (called as the period) to access the data members of a class.

//accessing a function 
obj.function_name()

Example: Putting them together

'use strict' 
class Polygon { 
   constructor(height, width) { 
      this.h = height; 
      this.w = width;
   } 
   test() { 
      console.log("The height of the polygon: ", this.h) 
      console.log("The width of the polygon: ",this. w) 
   } 
} 

//creating an instance  
var polyObj = new Polygon(10,20); 
polyObj.test();

The Example given above declares a class ‘Polygon’. The class’s constructor takes two arguments - height and width respectively. The ‘this’ keyword refers to the current instance of the class. In other words, the constructor above initializes two variables h and w with the parameter values passed to the constructor. The test () function in the class, prints the values of the height and width.

To make the script functional, an object of the class Polygon is created. The object is referred to by the polyObj variable. The function is then called via this object.

The following output is displayed on successful execution of the above code.

The height of the polygon:  10 
The width of the polygon:  20

Setters and Getters

Setters

A setter function is invoked when there is an attempt to set the value of a property. The set keyword is used to define a setter function. The syntax for defining a setter function is given below −

{set prop(val) { . . . }}
{set [expression](val) { . . . }}

prop is the name of the property to bind to the given function. val is an alias for the variable that holds the value attempted to be assigned to property. expression with ES6, can be used as a property name to bind to the given function.

Example

<script>
   class Student {
      constructor(rno,fname,lname){
         this.rno = rno
         this.fname = fname
         this.lname = lname
         console.log('inside constructor')
      }
      set rollno(newRollno){
         console.log("inside setter")
         this.rno = newRollno
      }
   }
   let s1 = new Student(101,'Sachin','Tendulkar')
   console.log(s1)
   //setter is called
   s1.rollno = 201
   console.log(s1)
</script>

The above example defines a class Student with three properties namely rno, fname and lname. A setter function rollno() is used to set the value for the rno property.

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

inside constructor
Student {rno: 101, fname: "Sachin", lname: "Tendulkar"}
inside setter
Student {rno: 201, fname: "Sachin", lname: "Tendulkar"}

Example

The following example shows how to use an expression as a property name with a setter function.

<script>
   let expr = 'name';
      let obj = {
      fname: 'Sachin',
      set [expr](v) { this.fname = v; }
   };
   console.log(obj.fname);
   obj.name = 'John';
   console.log(obj.fname);
</script>

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

Sachin
John

Getters

A getter function is invoked when there is an attempt to fetch the value of a property. The get keyword is used to define a getter function. The syntax for defining a getter function is given below −

{get prop() { ... } }
{get [expression]() { ... } }

prop is the name of the property to bind to the given function.

expression − Starting with ES6, you can also use expressions as a property name to bind to the given function.

Example

<script>
   class Student {
      constructor(rno,fname,lname){
         this.rno = rno
         this.fname = fname
         this.lname = lname
         console.log('inside constructor')
      }
      get fullName(){
         console.log('inside getter')
         return this.fname + " - "+this.lname
      }
   }
   let s1 = new Student(101,'Sachin','Tendulkar')
   console.log(s1)
   //getter is called
   console.log(s1.fullName)
</script>

The above example defines a class Student with three properties namely rno, fname and lname. The getter function fullName() concatenates the fname and lname and returns a new string.

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

inside constructor
Student {rno: 101, fname: "Sachin", lname: "Tendulkar"}
inside getter
Sachin - Tendulkar

Example

The following example shows how to use an expression as a property name with a getter function −

<script>
   let expr = 'name';
   let obj = {
      get [expr]() { return 'Sachin'; }
   };
   console.log(obj.name);
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

Sachin

स्थैतिक खोजशब्द

स्थिर कीवर्ड को एक कक्षा में कार्यों के लिए लागू किया जा सकता है। स्टैटिक सदस्यों को वर्ग नाम से संदर्भित किया जाता है।

उदाहरण

'use strict' 
class StaticMem { 
   static disp() { 
      console.log("Static Function called") 
   } 
} 
StaticMem.disp() //invoke the static metho

Note- कंस्ट्रक्टर की परिभाषा को शामिल करना अनिवार्य नहीं है। डिफ़ॉल्ट रूप से हर वर्ग में डिफ़ॉल्ट रूप से एक कंस्ट्रक्टर होता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Static Function called

Instof ऑपरेटर

यदि ऑब्जेक्ट निर्दिष्ट प्रकार का है, तो Instof ऑपरेटर सही लौटाता है।

उदाहरण

'use strict' 
class Person{ } 
var obj = new Person() 
var isPerson = obj instanceof Person; 
console.log(" obj is an instance of Person " + isPerson);

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

obj is an instance of Person True

कक्षा में प्रवेश

ES6 की अवधारणा का समर्थन करता है Inheritance। वंशानुक्रम एक मौजूदा इकाई से नई संस्थाएं बनाने के लिए एक कार्यक्रम की क्षमता है - यहां एक वर्ग। नए वर्ग बनाने के लिए जिस वर्ग का विस्तार किया जाता है, उसे कहा जाता हैparent class/super class। नव निर्मित वर्गों को कहा जाता हैchild/sub classes

एक वर्ग 'फैली हुई' कीवर्ड का उपयोग करके दूसरे वर्ग से विरासत में मिला है। चाइल्ड क्लासेस पैरेंट क्लास से कंस्ट्रक्टर्स को छोड़कर सभी प्रॉपर्टी और तरीके विरासत में लेते हैं।

निम्नलिखित के लिए सिंटैक्स है।

class child_class_name extends parent_class_name

उदाहरण: क्लास इनहेरिटेंस

'use strict' 
class Shape { 
   constructor(a) { 
      this.Area = a
   } 
} 
class Circle extends Shape { 
   disp() { 
      console.log("Area of the circle:  "+this.Area) 
   } 
} 
var obj = new Circle(223); 
obj.disp()

उपरोक्त उदाहरण एक वर्ग आकृति की घोषणा करता है। वर्ग को सर्किल वर्ग द्वारा विस्तारित किया जाता है। चूंकि, कक्षाओं, बाल वर्ग के बीच एक अंतर्निहित संबंध है, अर्थात, कक्षा सर्कल को अपने मूल वर्ग विशेषता अर्थात क्षेत्र में एक अंतर्निहित पहुंच मिलती है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Area of Circle: 223

वंशानुक्रम को इस प्रकार वर्गीकृत किया जा सकता है -

  • Single - प्रत्येक वर्ग एक मूल वर्ग से सबसे अधिक विस्तार कर सकता है।

  • Multiple- एक वर्ग कई वर्गों से वारिस हो सकता है। ES6 एकाधिक वंशानुक्रम का समर्थन नहीं करता है।

  • Multi-level - निम्नलिखित उदाहरण पर विचार करें।

'use strict' 
class Root { 
   test() { 
      console.log("call from parent class") 
   } 
} 
class Child extends Root {} 
class Leaf extends Child   

//indirectly inherits from Root by virtue of inheritance {} 
var obj = new Leaf();
obj.test()

क्लास लीफ मल्टीलेवल इनहेरिटेंस के गुण द्वारा रूट और चाइल्ड क्लासेस से विशेषताओं को प्राप्त करता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

call from parent class

क्लास इनहेरिटेंस और मेथड ओवरराइडिंग

Method Overridingएक ऐसा तंत्र है जिसके द्वारा बालक वर्ग सुपरक्लास पद्धति को पुनर्परिभाषित करता है। निम्नलिखित उदाहरण से पता चलता है -

'use strict' ;
class PrinterClass { 
   doPrint() { 
      console.log("doPrint() from Parent called… ");
   }
}
class StringPrinter extends PrinterClass { 
   doPrint() { 
      console.log("doPrint() is printing a string…"); 
   } 
} 
var obj = new StringPrinter(); 
obj.doPrint();

उपरोक्त उदाहरण में, बाल वर्ग ने सुपरक्लास फ़ंक्शन के कार्यान्वयन को बदल दिया है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

doPrint() is printing a string…

सुपर कीवर्ड

ES6 एक चाइल्ड क्लास को उसके पैरेंट क्लास डेटा मेंबर को इनवाइट करने में सक्षम बनाता है। इस का उपयोग करके हासिल किया हैsuperकीवर्ड। सुपर कीवर्ड का उपयोग किसी वर्ग के तत्काल अभिभावक को संदर्भित करने के लिए किया जाता है।

निम्नलिखित उदाहरण पर विचार करें -

'use strict' 
class PrinterClass { 
   doPrint() {
      console.log("doPrint() from Parent called…") 
   } 
}  
class StringPrinter extends PrinterClass { 
   doPrint() { 
      super.doPrint() 
      console.log("doPrint() is printing a string…") 
   } 
} 
var obj = new StringPrinter() 
obj.doPrint()

doPrint()StringWriter वर्ग में पुनर्परिभाषित, इसके मूल वर्ग संस्करण के लिए कॉल जारी करता है। दूसरे शब्दों में, सुपर कीवर्ड का उपयोग पैरेंट क्लास - प्रिंटरक्लास में doPrint () फ़ंक्शन की परिभाषा को लागू करने के लिए किया जाता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

doPrint() from Parent called. 
doPrint() is printing a string.

ईएस 6 ने दो नए डेटा स्ट्रक्चर पेश किए - maps तथा sets। आइए उनके बारे में विस्तार से जानें।

एमएपीएस

एक नक्शा का आदेश दिया संग्रह है key-value pairs। मानचित्र वस्तुओं के समान हैं। हालांकि, नक्शे और वस्तुओं के बीच कुछ अंतर हैं। ये नीचे सूचीबद्ध हैं -

अनु क्रमांक वस्तु नक्शा
1 कुंजी वस्तु प्रकार नहीं हो सकते कुंजी किसी भी प्रकार की हो सकती है
2 चाबी का आदेश नहीं दिया जाता है चाबी का आदेश दिया जाता है
3 न चलने योग्य iterable

वाक्य - विन्यास

मानचित्र का सिंटैक्स नीचे दिया गया है -

let map = new Map([iterable])
let map = new Map()

उदाहरण

निम्न उदाहरण एक पुनरावृत्त कंस्ट्रक्टर का उपयोग करके एक मानचित्र बनाता है -

<script>
   let andy = {ename:"Andrel"},
      varun = {ename:"Varun"},
      prijin = {ename:"Prijin"}
   let empJobs = new Map([
   [andy,'Software Architect'],
   [varun,'Developer']]
   );
   console.log(empJobs)
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

{{…} => "Software Architect", {…} => "Developer"}

नक्शे के आकार की जाँच

आकार की संपत्ति का उपयोग मानचित्र में संग्रहीत मूल्यों की संख्या निर्धारित करने के लिए किया जा सकता है।

वाक्य - विन्यास

मानचित्र का आकार जाँचने का सिंटैक्स नीचे दिया गया है -

map_name.size

उदाहरण

<script>
   let daysMap = new Map();
   daysMap.set('1', 'Monday');
   daysMap.set('2', 'Tuesday');
   daysMap.set('3', 'Wednesday');
   console.log(daysMap.size);
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

3

निम्नलिखित कुछ सामान्य तरीके हैं जिनका उपयोग मानचित्रों में हेरफेर करने के लिए किया जा सकता है -

अनु क्रमांक ऑब्जेक्ट और मैप
1 सेट (कुंजी, मूल्य)

मानचित्र में कुंजी और मान जोड़ता है

2 चाबी देना)

यदि कुंजी मिलान किया जाता है, तो मान लौटाता है

3 है (कुंजी)

निर्दिष्ट कुंजी के साथ एक तत्व मौजूद है, तो सच है; और गलत है

4 चांबियाँ()

मैप ऑब्जेक्ट में प्रत्येक तत्व के लिए कुंजियों को शामिल करने वाला एक पुनरावृत्ति देता है

5 मूल्यों ()

मैप ऑब्जेक्ट में प्रत्येक तत्व के लिए मान शामिल करने वाला एक पुनरावृत्ति देता है

6 प्रविष्टियों ()

मैप में प्रत्येक तत्व के लिए कुंजी-वैल्यू जोड़े वाले एक पुनरावृत्ति देता है

7 हटाएँ (key)

मैप ऑब्जेक्ट से निर्दिष्ट तत्व निकालता है

WeakMap

कमजोर नक्शा एक छोटा सा है subset of map। कुंजी को कमजोर रूप से संदर्भित किया जाता है, इसलिए यह केवल गैर-आदिम हो सकता है। यदि ऑब्जेक्ट कुंजियों का कोई संदर्भ नहीं है, तो यह कचरा संग्रह के अधीन होगा।

  • न चलने योग्य
  • हर कुंजी ऑब्जेक्ट प्रकार है

यदि कोई संदर्भ नहीं है, तो WeakMap कचरा संग्रहण की अनुमति देगा।

वाक्य - विन्यास

WeakMap के लिए वाक्य रचना नीचे बताया गया है -

new WeakMap([iterable])

उदाहरण 1

<script>
   let emp = new WeakMap();
   emp.set(10,'Sachin');// TypeError as keys should be object
</script>

उदाहरण 2

<script>
   let empMap = new WeakMap();
   // emp.set(10,'Sachin');// Error as keys should be object
   let e1= {ename:'Kiran'},
      e2 = {ename:'Kannan'},
      e3 = {ename:'Mohtashim'}

   empMap.set(e1,1001);
   empMap.set(e2,1002);
   empMap.set(e3,1003);

   console.log(empMap)
   console.log(empMap.get(e2))
   console.log(empMap.has(e2))
   empMap.delete(e1)
   console.log(empMap)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार है -

{{…} => 1002, {…} => 1003, {…} => 1001}
1002
true
{{…} => 1002, {…} => 1003}

सेट

एक सेट अद्वितीय मूल्यों का एक अनियंत्रित संग्रह है। इस डेटा संरचना में आदिम और वस्तु प्रकार के मूल्य हो सकते हैं।

वाक्य - विन्यास

सेट के लिए वाक्य रचना नीचे दिया गया है -

new Set([iterable])
new Set()

उदाहरण

<script>
   let names = new Set(['A','B','C','D']);
   console.log(names)
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

{"A", "B", "C", "D"}

एक सेट के आकार की जाँच करना

सेट ऑब्जेक्ट का आकार गुण सेट में तत्वों की संख्या को क्वेरी करने के लिए उपयोग किया जा सकता है।

वाक्य - विन्यास

सेट के आकार की जाँच करने के लिए वाक्यविन्यास नीचे उल्लिखित है -

set.size

उदाहरण

<script>
   let names = new Set(['A','B','C','D']);
   console.log(names.size)
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

4

एक सेट Iterating

हम उपयोग कर सकते हैं forEach तथा for..ofएक सेट के माध्यम से पुनरावृति करने के लिए छोरों। यह नीचे दिए गए उदाहरण में दिखाया गया है -

उदाहरण

<script>
   let names= new Set(['A','B','C','D']);
   //iterate using forEach
   console.log('forEach')
   names.forEach(n=>console.log(n))
   
   console.log('for of..')
   
   //iterate using for..of
   for(let n of names){
      console.log(n)
   }
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार है -

forEach
A
B
C
D
for of..
A
B
C
D

सेट में हेरफेर करने के लिए निम्नलिखित विधियों का उपयोग किया जा सकता है -

अनु क्रमांक ऑब्जेक्ट और मैप
1 ऐड (तत्व)

सेट करने के लिए एक तत्व जोड़ता है

2 (तत्व) है

तत्व मिले तो सही; और गलत है

3 हटाएँ (तत्व)

सेट से विशिष्ट तत्व हटाएं

4 स्पष्ट()

सेट से सभी तत्वों को साफ करता है

WeakSet

एक Weakset ऑब्जेक्ट को कमजोर रूप से रखता है, इसका मतलब है कि WeakSet में संग्रहीत ऑब्जेक्ट कचरा संग्रह के अधीन है, यदि वे संदर्भित नहीं हैं। WeakSets चलने योग्य नहीं हैं और इनमें नहीं हैget तरीका।

<script>

   let e1 = {ename:'A'}
   let e2 ={ename:'B'}
   let e3 ={ename:'C'}

   let emps = new WeakSet();
   emps.add(e1);
   emps.add(e2)
   .add(e3);

   console.log(emps)
   console.log(emps.has(e1))
   emps.delete(e1);
   console.log(emps)
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

WeakSet {{…}, {…}, {…}}
true
WeakSet {{…}, {…}}

ईएस 6 - वादे

वादा सिंटेक्स

वचन से संबंधित सिंटेक्स का उल्लेख नीचे किया गया है, जहां, p वादा वस्तु है, resolve वह फ़ंक्शन है जिसे तब कॉल किया जाना चाहिए जब वादा सफलतापूर्वक निष्पादित होता है और reject फ़ंक्शन वह है जिसे तब कॉल किया जाना चाहिए जब वादा एक त्रुटि का सामना करता है।

let p = new Promise(function(resolve,reject){
   let workDone = true; // some time consuming work
      if(workDone){
      //invoke resolve function passed
      
	  resolve('success promise completed')
   }
   else{
      reject('ERROR , work could not be completed')
   }
})

उदाहरण

नीचे दिया गया उदाहरण एक फ़ंक्शन दिखाता है 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;
   }

   add_positivenos_async(10, 20)
      .then(successHandler) // if promise resolved
      .catch(errorHandler);// if promise rejected

   add_positivenos_async(-10, -20)
      .then(successHandler) // if promise resolved
      .catch(errorHandler);// if promise rejected

   function errorHandler(err) {
      console.log('Handling error', err)
   }
   function successHandler(result) {
      console.log('Handling success', result)
   }

   console.log('end')
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

end
Handling success 30
Handling error NOT_Postive_Number_Passed

चैनिंग का वादा किया

Promises chaining जब हम एक अनुक्रम है इस्तेमाल किया जा सकता है asynchronous tasksएक के बाद एक किया जाना। जब एक वादा दूसरे वादे के परिणाम पर निर्भर करता है तो वादे जंजीर होते हैं। यह नीचे दिए गए उदाहरण में दिखाया गया है

उदाहरण

नीचे दिए गए उदाहरण में, add_positivenos_async() functionदो संख्याओं को अतुल्यकालिक रूप से जोड़ता है और यदि नकारात्मक मान पारित किया जाता है तो अस्वीकार कर देता है। वर्तमान अतुल्यकालिक फ़ंक्शन कॉल से परिणाम बाद के फ़ंक्शन कॉल के पैरामीटर के रूप में पारित किया जाता है। प्रत्येक नोट करेंthen() पद्धति में एक वापसी विवरण है।

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

   add_positivenos_async(10,20)
   .then(function(result){
      console.log("first result",result)
      return add_positivenos_async(result,result)
   }).then(function(result){
   console.log("second result",result)
      return add_positivenos_async(result,result)
   }).then(function(result){
      console.log("third result",result)
   })

   console.log('end')
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

end
first result 30
second result 60
third result 120

वादा वस्तु के कुछ सामान्य उपयोग के तरीके नीचे विस्तार से चर्चा की गई है -

promise.all ()

यह विधि कई वादों के परिणामों को एकत्र करने के लिए उपयोगी हो सकती है।

वाक्य - विन्यास

के लिए वाक्यविन्यास promise.all() विधि का उल्लेख नीचे दिया गया है, जहां, iterableएक चलने योग्य वस्तु है। जैसे ऐरे।

Promise.all(iterable);

उदाहरण

नीचे दिया गया उदाहरण अतुल्यकालिक संचालन की एक सरणी निष्पादित करता है [add_positivenos_async(10,20),add_positivenos_async(30,40),add_positivenos_async(50,60)]। जब सभी ऑपरेशन पूरे हो जाते हैं, तो वादा पूरी तरह से हल हो जाता है।

<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;
   }
   //Promise.all(iterable)

Promise.all([add_positivenos_async(10,20),add_positivenos_async(30,40),add_positivenos_async(50,60)])
   .then(function(resolveValue){
      console.log(resolveValue[0])
      console.log(resolveValue[1])
      console.log(resolveValue[2])
      console.log('all add operations done')
   })
   .catch(function(err){
      console.log('Error',err)
   })
   console.log('end')
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

end
30
70
110
all add operations done

promise.race ()

यह फ़ंक्शन वादों की एक सरणी लेता है और पहले वादे का निपटान करता है।

वाक्य - विन्यास

के लिए वाक्यविन्यास promise.race()फ़ंक्शन का उल्लेख नीचे किया गया है, जहां, पुनरावृत्त एक चलने योग्य वस्तु है। जैसे ऐरे।

Promise.race(iterable)

उदाहरण

नीचे दिया गया उदाहरण एक सरणी लेता है [add_positivenos_async(10,20),add_positivenos_async(30,40)] अतुल्यकालिक संचालन के।

जब भी ऐड ऑपरेशन में से कोई एक पूरा होता है तो वादा हल हो जाता है। वादा अन्य अतुल्यकालिक संचालन के पूरा होने का इंतजार नहीं करेगा।

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

   //Promise.race(iterable)
   Promise.race([add_positivenos_async(10,20),add_positivenos_async(30,40)])
   .then(function(resolveValue){
      console.log('one of them is done')
      console.log(resolveValue)
   }).catch(function(err){
      console.log("Error",err)
   })

   console.log('end')
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

end
one of them is done
30

Promisesजावास्क्रिप्ट (ES6 नई सुविधा) में async प्रोग्रामिंग को लागू करने का एक साफ तरीका है। वादों से पहले, कॉलबैक का उपयोग एसिंक्स प्रोग्रामिंग को लागू करने के लिए किया गया था। आइए, कॉलबैक का उपयोग करके यह बताएं कि Async प्रोग्रामिंग क्या है और इसका कार्यान्वयन क्या है।

कॉलबैक को समझना

एक फ़ंक्शन को दूसरे फ़ंक्शन के पैरामीटर के रूप में पारित किया जा सकता है। इस तंत्र को एक के रूप में कहा जाता हैCallback। एक कॉलबैक घटनाओं में सहायक होगा।

निम्नलिखित उदाहरण हमें इस अवधारणा को बेहतर ढंग से समझने में मदद करेंगे।

<script>   
   function notifyAll(fnSms, fnEmail) {   
      console.log('starting notification process');   
      fnSms();   
      fnEmail();   
   }   
   notifyAll(function() {   
      console.log("Sms send ..");   
   }, 
   function() {   
      console.log("email send ..");   
   });   
   console.log("End of script"); 
   //executes last or blocked by other methods   
</script>

में notifyAll()ऊपर दिखाया गया तरीका, अधिसूचना एसएमएस भेजकर और ई-मेल भेजकर होती है। इसलिए, InformAll विधि के आक्रमणकर्ता को दो कार्यों को मापदंडों के रूप में पारित करना होगा। प्रत्येक फ़ंक्शन एसएमएस भेजने और ई-मेल भेजने जैसी एकल जिम्मेदारी लेता है।

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

starting notification process 
Sms send .. 
Email send .. 
End of script

ऊपर वर्णित कोड में, फ़ंक्शन कॉल सिंक्रोनस हैं। इसका मतलब है कि यूआई धागा पूरी अधिसूचना प्रक्रिया को पूरा करने के लिए इंतजार कर रहा होगा। सिंक्रोनस कॉल अवरुद्ध कॉल बन जाते हैं। आइए अब गैर-अवरुद्ध या async कॉल को समझें।

AsyncCallback को समझना

उपरोक्त उदाहरण पर विचार करें।

स्क्रिप्ट को सक्षम करने के लिए, अतुल्यकालिक या गैर-अवरोधक कॉल को InformAll () विधि से निष्पादित करें। हम उपयोग करेंगेsetTimeout()जावास्क्रिप्ट की विधि। यह विधि डिफ़ॉल्ट रूप से async है।

सेटटाइमआउट () विधि में दो पैरामीटर हैं -

  • एक कॉलबैक फ़ंक्शन।

  • सेकंड की संख्या जिसके बाद विधि कहा जाएगा।

इस मामले में, अधिसूचना प्रक्रिया को टाइमआउट के साथ लपेटा गया है। इसलिए, कोड द्वारा निर्धारित दो सेकंड की देरी होगी। इनफॉर्मल () को लागू किया जाएगा और मुख्य धागा अन्य तरीकों को निष्पादित करने की तरह आगे बढ़ता है। इसलिए, अधिसूचना प्रक्रिया मुख्य जावास्क्रिप्ट थ्रेड को ब्लॉक नहीं करेगी।

<script>   
   function notifyAll(fnSms, fnEmail) {   
      setTimeout(function() {   
         console.log('starting notification process');   
         fnSms();   
         fnEmail();   
      }, 2000);   
   }   
   notifyAll(function() {   
      console.log("Sms send ..");   
   },  
   function() {   
      console.log("email send ..");   
   });   
   console.log("End of script"); //executes first or not blocked by others   
</script>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

End of script 
starting notification process 
Sms send .. 
Email send ..

कई कॉलबैक के मामले में, कोड डरावना लगेगा।

<script>   
   setTimeout(function() {   
      console.log("one");   
      setTimeout(function() {   
         console.log("two");   
         setTimeout(function() {   
            console.log("three");   
         }, 1000);   
      }, 1000);   
   }, 1000);   
</script>

ईएस 6 वादों की अवधारणा को पेश करके आपके बचाव में आता है। वादे "निरंतरता की घटनाएँ" हैं और वे आपको एक बहुत क्लीनर कोड शैली में एक साथ कई async संचालन निष्पादित करने में मदद करते हैं।

उदाहरण

आइए इसे एक उदाहरण से समझते हैं। निम्नलिखित के लिए सिंटैक्स है।

var promise = new Promise(function(resolve , reject) {    
   // do a thing, possibly async , then..  
   if(/*everthing turned out fine */)    resolve("stuff worked");  
   else     
   reject(Error("It broke"));  
});  
return promise;
// Give this to someone

वादों को लागू करने की दिशा में पहला कदम एक ऐसी विधि तैयार करना है जो वादे का उपयोग करेगी। आइए इस उदाहरण में कहते हैं,getSum()विधि अतुल्यकालिक है अर्थात इसका संचालन अन्य तरीकों के निष्पादन को अवरुद्ध नहीं करना चाहिए। जैसे ही यह ऑपरेशन पूरा होता है, यह बाद में कॉलर को सूचित करेगा।

निम्न उदाहरण (चरण 1) एक वादा वस्तु 'var वादा' की घोषणा करता है। प्रॉमिस कंस्ट्रक्टर कार्य के सफल समापन के लिए पहले कार्यों में ले जाता है और दूसरे में त्रुटि होने पर।

वादा कॉलबैक का उपयोग करके और परिणाम में पास होने के द्वारा गणना का परिणाम देता है, अर्थात, n1 + n2

Step 1 - संकल्प (n1 + n2);

यदि getSum () एक त्रुटि या अप्रत्याशित स्थिति का सामना करता है, तो यह वादा में अस्वीकार कॉलबैक विधि को आमंत्रित करेगा और कॉल करने वाले को त्रुटि जानकारी पारित करेगा।

Step 2 - अस्वीकार (त्रुटि ("नकारात्मक समर्थित नहीं"));

विधि कार्यान्वयन निम्नलिखित कोड (STEP 1) में दिया गया है।

function getSum(n1, n2) {   
   varisAnyNegative = function() {   
      return n1 < 0 || n2 < 0;   
   }   
   var promise = new Promise(function(resolve, reject) {   
      if (isAnyNegative()) {   
         reject(Error("Negatives not supported"));   
      }   
      resolve(n1 + n2)
   });   
   return promise;   
}

दूसरा चरण कॉल करने वाले (STEP 2) के कार्यान्वयन का विवरण देता है।

कॉल करने वाले को 'तत्कालीन' पद्धति का उपयोग करना चाहिए, जिसमें कॉलबैक के दो तरीके हैं - पहला सफलता के लिए और दूसरा असफलता के लिए। प्रत्येक विधि एक पैरामीटर लेता है, जैसा कि निम्नलिखित कोड में दिखाया गया है।

getSum(5, 6)   
.then(function (result) {   
   console.log(result);   
},   
function (error) {   
   console.log(error);   
});

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

11

चूंकि गेटसम का वापसी प्रकार () एक वादा है, हम वास्तव में कई 'फिर' बयान दे सकते हैं। पहले 'फिर' में रिटर्न स्टेटमेंट होगा।

getSum(5, 6)   
.then(function(result) {   
   console.log(result);   
   returngetSum(10, 20); 
   // this returns another promise   
},   
function(error) {   
   console.log(error);   
})   
.then(function(result) {   
   console.log(result);   
}, 
function(error) {   
   console.log(error);
});

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

11
30

निम्न उदाहरण तीन तो () getSum () विधि के साथ कॉल करता है।

<script>   
   function getSum(n1, n2) {   
      varisAnyNegative = function() {   
         return n1 < 0 || n2 < 0;   
      }   
      var promise = new Promise(function(resolve, reject) {   
         if (isAnyNegative()) {   
            reject(Error("Negatives not supported"));   
         }   
         resolve(n1 + n2);   
      });   
      return promise;   
   }   
   getSum(5, 6)   
   .then(function(result) {   
      console.log(result);   
      returngetSum(10, 20); 
      //this returns another Promise   
   },   
   function(error) {   
      console.log(error);   
   })
   .then(function(result) {   
      console.log(result);   
      returngetSum(30, 40); 
      //this returns another Promise   
   }, 
   function(error) {   
      console.log(error);   
   })   
   .then(function(result) {   
      console.log(result);   
   }, 
   function(error) {         
      console.log(error);   
   });   
   console.log("End of script ");   
</script>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

कार्यक्रम पहले 'स्क्रिप्ट के अंत' को प्रदर्शित करता है और फिर गेट्सम () विधि से, एक-एक करके कॉल करता है।

End of script  
11 
30 
70

यह पता चलता है getSum () को async स्टाइल या नॉन-ब्लॉकिंग स्टाइल में कहा जाता है। वादा कॉलबैक से निपटने के लिए एक अच्छा और साफ तरीका देता है।

ईएस 6 - मॉड्यूल

परिचय

एक परिदृश्य पर विचार करें जहां जावास्क्रिप्ट कोड के कुछ हिस्सों को पुन: उपयोग करने की आवश्यकता होती है। ES6 की अवधारणा के साथ अपने बचाव के लिए आता है Modules

एक मॉड्यूल जावास्क्रिप्ट कोड के संबंधित सेट का आयोजन करता है। एक मॉड्यूल में चर और फ़ंक्शन हो सकते हैं। एक मॉड्यूल एक फ़ाइल में लिखे गए जावास्क्रिप्ट कोड का एक हिस्सा से ज्यादा कुछ नहीं है। डिफ़ॉल्ट रूप से, एक मॉड्यूल के चर और फ़ंक्शन उपयोग के लिए उपलब्ध नहीं हैं। एक मॉड्यूल के भीतर चर और कार्यों को निर्यात किया जाना चाहिए ताकि उन्हें अन्य फ़ाइलों के भीतर से एक्सेस किया जा सके। ईएस 6 में मॉड्यूल केवल में काम करते हैंstrict mode। इसका मतलब है कि मॉड्यूल में घोषित चर या फ़ंक्शन वैश्विक स्तर पर सुलभ नहीं होंगे।

एक मॉड्यूल का निर्यात

निर्यात कीवर्ड का उपयोग किसी मॉड्यूल में घटकों को निर्यात करने के लिए किया जा सकता है। एक मॉड्यूल में निर्यात निम्नानुसार वर्गीकृत किया जा सकता है -

  • नाम दिया गया निर्यात
  • डिफ़ॉल्ट निर्यात

नाम दिया गया निर्यात

नामांकित निर्यात उनके नाम से प्रतिष्ठित हैं। एक मॉड्यूल में कई नामित निर्यात हो सकते हैं। एक मॉड्यूल चयनित घटकों को नीचे दिए गए सिंटैक्स का उपयोग करके निर्यात कर सकता है -

Syntax 1

//using multiple export keyword
export component1
export component2
...
...
export componentN

Syntax 2

वैकल्पिक रूप से, एक मॉड्यूल में घटकों को एकल निर्यात कीवर्ड के साथ निर्यात किया जा सकता है, जो नीचे दिखाए गए अनुसार {} बाइंडिंग सिंटैक्स के साथ है -

//using single export keyword

export {component1,component2,....,componentN}

डिफ़ॉल्ट निर्यात

ऐसे मॉड्यूल जिन्हें केवल एक मूल्य का निर्यात करने की आवश्यकता है, वे डिफ़ॉल्ट निर्यात का उपयोग कर सकते हैं। प्रति मॉड्यूल केवल एक डिफ़ॉल्ट निर्यात हो सकता है।

Syntax

export default component_name

हालांकि, एक मॉड्यूल में एक ही समय में एक डिफ़ॉल्ट निर्यात और कई नामित निर्यात हो सकते हैं।

एक मॉड्यूल आयात करना

एक मॉड्यूल का उपभोग करने में सक्षम होने के लिए, का उपयोग करें import keyword। एक मॉड्यूल में कई हो सकते हैंimport statements

नामांकित निर्यात आयात करना

नामित निर्यात आयात करते समय, संबंधित घटकों के नाम मेल खाना चाहिए।

Syntax

import {component1,component2..componentN} from module_name

हालाँकि, नामित निर्यात आयात करते समय, उन्हें कीवर्ड के रूप में उपयोग करके बदला जा सकता है। नीचे दिए गए वाक्यविन्यास का उपयोग करें -

import {original_component_name as new_component_name }

सभी नामित निर्यातों को तारांकन के उपयोग से किसी वस्तु पर आयात किया जा सकता है * operator

import * as variable_name from module_name

डिफ़ॉल्ट निर्यात आयात करना

नामित निर्यातों के विपरीत, किसी भी नाम के साथ एक डिफ़ॉल्ट निर्यात आयात किया जा सकता है।

Syntax

import any_variable_name from module_name

उदाहरण: नामांकित निर्यात

Step 1 - एक फ़ाइल company1.js बनाएं और निम्नलिखित कोड जोड़ें -

let company = "TutorialsPoint"

let getCompany = function(){
   return company.toUpperCase()
}

let setCompany = function(newValue){
   company = newValue
}

export {company,getCompany,setCompany}

Step 2- एक फ़ाइल company2.js बनाएँ। यह फ़ाइल company1.js फ़ाइल में परिभाषित घटकों का उपभोग करती है। मॉड्यूल आयात करने के लिए निम्नलिखित में से किसी भी दृष्टिकोण का उपयोग करें।

Approach 1

import {company,getCompany} from './company1.js'

console.log(company)
console.log(getCompany())

Approach 2

import {company as x, getCompany as y} from './company1.js'

console.log(x)
console.log(y())

Approach 3

import * as myCompany from './company1.js'

console.log(myCompany.getCompany())
console.log(myCompany.company)

Step 3 - HTML फ़ाइल का उपयोग करके मॉड्यूल को निष्पादित करें

दोनों मॉड्यूल्स को निष्पादित करने के लिए हमें नीचे दिखाए अनुसार html फाइल बनाने की जरूरत है और इसे लाइव सर्वर में चलाएं। ध्यान दें कि हमें इसका उपयोग करना चाहिएattribute type="module" स्क्रिप्ट टैग में।

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>Document</title>
</head>
<body>
   <script src="./company2.js" type="module"></script>
</body>
</html>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

TutorialsPoint
TUTORIALSPOINT

डिफ़ॉल्ट निर्यात

Step 1 - एक फ़ाइल बनाएँ company1.js और निम्नलिखित कोड जोड़ें -

let name = 'TutorialsPoint'

let company = {
   getName:function(){
      return name
   },
   setName:function(newName){
      name = newName
   }
}

export default company

Step 2 - एक फ़ाइल बनाएँ company2.js। यह फ़ाइल company1.js फ़ाइल में परिभाषित घटकों को खाती है।

import c from './company1.js'
console.log(c.getName())
c.setName('Google Inc')
console.log(c.getName())

Step 3 - निष्पादित करें modules का उपयोग कर HTML file

दोनों मॉड्यूल्स को निष्पादित करने के लिए हमें नीचे दिखाए अनुसार html फाइल बनाने की जरूरत है और इसे लाइव सर्वर में चलाएं। ध्यान दें कि हमें इसका उपयोग करना चाहिएattribute type="module" स्क्रिप्ट टैग में।

<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <meta http-equiv="X-UA-Compatible" content="ie=edge">
   <title>Document</title>
</head>
<body>
   <script src="./company2.js" type="module"></script>
</body>
</html>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

TutorialsPoint
Google Inc

उदाहरण: डिफॉल्ट और नामांकित एक्सपोर्ट्स को मिलाना

Step 1 - एक फ़ाइल बनाएँ company1.js और निम्नलिखित कोड जोड़ें -

//named export
export let name = 'TutorialsPoint'

let company = {
   getName:function(){
      return name
   },
   setName:function(newName){
      name =newName
   }
}
//default export
export default company

Step 2 - एक फ़ाइल बनाएँ company2.js। यह फ़ाइल में परिभाषित घटकों का उपभोग करती हैcompany1.jsफ़ाइल। पहले डिफ़ॉल्ट निर्यात आयात करें, उसके बाद नामित निर्यात।

import c, {name} from './company1.js'

console.log(name)
console.log(c.getName())
c.setName("Mohtashim")
console.log(c.getName())

Step 3 - HTML फ़ाइल का उपयोग करके मॉड्यूल को निष्पादित करें

<!DOCTYPE html>
<html lang="en">
   <head>
      <meta charset="UTF-8">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <meta http-equiv="X-UA-Compatible" content="ie=edge">
      <title>Document</title>
   </head>
   <body>
      <script src="company2.js" type="module"></script>
   </body>
</html>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

TutorialsPoint
TutorialsPoint
Mohtashim

ES6 - त्रुटि से निपटने

प्रोग्रामिंग में तीन प्रकार की त्रुटियां हैं: सिंटेक्स एरर्स, रनटाइम एरर्स और लॉजिकल एरर्स।

सिंटेक्स त्रुटियां

सिंटैक्स त्रुटियां, जिन्हें कहा जाता है parsing errors, पारंपरिक प्रोग्रामिंग भाषाओं में संकलन समय और जावास्क्रिप्ट में व्याख्या के समय पर होते हैं। जब सिंटैक्स में कोई त्रुटि होती है, सिंटैक्स त्रुटि के रूप में केवल उसी थ्रेड के भीतर मौजूद कोड प्रभावित होता है और अन्य थ्रेड्स में कोड के बाकी कोड निष्पादित हो जाते हैं, जिसमें कुछ भी नहीं लगता है कि त्रुटि वाले कोड पर निर्भर करता है।

रनटाइम त्रुटियां

रनटाइम त्रुटियों को भी कहा जाता है exceptions, निष्पादन के दौरान (संकलन / व्याख्या के बाद)। अपवाद उस धागे को भी प्रभावित करते हैं जिसमें वे होते हैं, जिससे अन्य जावास्क्रिप्ट धागे सामान्य निष्पादन जारी रखने की अनुमति देते हैं।

तार्किक त्रुटियां

तर्क त्रुटियों को ट्रैक करने के लिए त्रुटियों का सबसे कठिन प्रकार हो सकता है। ये त्रुटियाँ सिंटैक्स या रनटाइम त्रुटि का परिणाम नहीं हैं। इसके बजाय, वे तब होते हैं जब आप तर्क में गलती करते हैं जो आपकी स्क्रिप्ट को ड्राइव करता है और आपको अपेक्षित परिणाम नहीं मिलता है।

आप उन त्रुटियों को नहीं पकड़ सकते, क्योंकि यह आपकी व्यावसायिक आवश्यकता पर निर्भर करता है कि आप अपने कार्यक्रम में किस प्रकार का तर्क रखना चाहते हैं।

रनटाइम त्रुटि होने पर जावास्क्रिप्ट त्रुटि वस्तु के उदाहरणों को फेंकता है। निम्न तालिका त्रुटि ऑब्जेक्ट के पूर्वनिर्धारित प्रकारों को सूचीबद्ध करती है।

अनु क्रमांक त्रुटि वस्तु और विवरण
1

EvalError

एक त्रुटि बनाता है जो वैश्विक फ़ंक्शन के संबंध में एक त्रुटि का प्रतिनिधित्व करता है eval()

2

RangeError

एक त्रुटि का प्रतिनिधित्व करने वाले एक उदाहरण को बनाता है जब एक संख्यात्मक चर या पैरामीटर इसकी वैध सीमा के बाहर होता है।

3

ReferenceError

एक त्रुटि का प्रतिनिधित्व करने वाले एक उदाहरण को बनाता है जो एक अमान्य संदर्भ को डीफ़र करते हैं।

4

SyntaxError

कोड को पार्स करते समय होने वाली सिंटैक्स त्रुटि का प्रतिनिधित्व करने वाला एक उदाहरण बनाता है।

5

TypeError

एक त्रुटि का प्रतिनिधित्व करता है जो तब होता है जब एक चर या पैरामीटर मान्य प्रकार का नहीं होता है।

6

URIError

एक त्रुटि का प्रतिनिधित्व करते हुए एक उदाहरण बनाता है जो तब होता है encodeURI() या decodeURI() अमान्य पैरामीटर पारित किए गए हैं।

अपवाद फेंकना

का उपयोग करके एक त्रुटि (पूर्वनिर्धारित या उपयोगकर्ता परिभाषित) को उठाया जा सकता है throw statement। बाद में इन अपवादों को पकड़ा जा सकता है और आप एक उचित कार्रवाई कर सकते हैं। निम्नलिखित के लिए सिंटैक्स है।

सिंटेक्स: एक सामान्य अपवाद को फेंकना

throw new Error([message]) 
OR 
throw([message])

सिंटेक्स: एक विशिष्ट अपवाद को फेंकना

throw new Error_name([message])

उपवाद सम्भालना

अपवाद हैंडलिंग एक के साथ पूरा किया है try...catch statement। जब कार्यक्रम एक अपवाद का सामना करता है, तो कार्यक्रम एक अनफेयर तरीके से समाप्त हो जाएगा। इस अप्रत्याशित त्रुटि के खिलाफ सुरक्षा के लिए, हम एक कोशिश ... कैच स्टेटमेंट में अपना कोड लपेट सकते हैं।

कोशिश ब्लॉक का पालन या तो एक कैच ब्लॉक या एक अंततः ब्लॉक (या दोनों में से एक) द्वारा किया जाना चाहिए। जब प्रयास ब्लॉक में अपवाद होता है, तो अपवाद ई में रखा जाता है और कैच ब्लॉक निष्पादित होता है। वैकल्पिक अंत में कोशिश / पकड़ के बाद बिना शर्त के निष्पादित होता है

निम्नलिखित के लिए सिंटैक्स है।

try {  
   // Code to run  
   [break;]  
} catch ( e ) {  
   // Code to run if an exception occurs
   [break;]  
}[ finally {  
   // Code that is always executed regardless of  
   // an exception occurring  
}]

उदाहरण

var a = 100; 
var b = 0; 
try { 
   if (b == 0 ) { 
      throw(“Divide by zero error.”); 
   } else { 
      var c = a / b; 
   } 
} 
catch( e ) { 
   console.log("Error: " + e ); 
}

उत्पादन

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Error: Divide by zero error

Note - नोट: आप एक फ़ंक्शन में एक अपवाद बढ़ा सकते हैं और फिर आप उस फ़ंक्शन को या उसी फ़ंक्शन का उपयोग करके कॉलर फ़ंक्शन में कैप्चर कर सकते हैं try...catch खंड मैथा।

ऑनरर () विधि

onerrorईवेंट हैंडलर जावास्क्रिप्ट में त्रुटि से निपटने की सुविधा प्रदान करने वाला पहला फीचर था। जब भी पृष्ठ पर कोई अपवाद होता है, त्रुटि घटना को विंडो ऑब्जेक्ट पर निकाल दिया जाता है।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         window.onerror  =  function () {  
            document.write ("An error occurred.");  
         } 
      </script> 
   </head> 

   <body> 
      <p>Click the following to see the result:</p> 
      <form> 
         <input type = "button" value = "Click Me" onclick = "myFunc();" /> 
      </form> 
   </body> 
</html>

उत्पादन

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

ऑनरर इवेंट हैंडलर त्रुटि की सटीक प्रकृति की पहचान करने के लिए तीन टुकड़े प्रदान करता है -

  • Error message - वही संदेश जो ब्राउज़र दिए गए त्रुटि के लिए प्रदर्शित करेगा।

  • URL - वह फाइल जिसमें त्रुटि हुई।

  • Line number - दिए गए URL में लाइन नंबर जो त्रुटि का कारण बना।

निम्न उदाहरण दिखाता है कि इस जानकारी को कैसे निकालना है।

उदाहरण

<html> 
   <head> 
      <script type = "text/javascript"> 
         window.onerror  =  function (msg, url, line) {  
            document.write ("Message : " + msg );  
            document.write ("url : " + url );  
            document.write ("Line number : " + line );  
         } 
      </script> 
   </head> 

   <body> 
      <p>Click the following to see the result:</p> 
      <form> 
         <input type = "button" value = "Click Me" onclick = "myFunc();" /> 
      </form> 
   </body> 
</html>

कस्टम त्रुटियां

जावास्क्रिप्ट कस्टम त्रुटियों की अवधारणा का समर्थन करता है। निम्नलिखित उदाहरण वही बताते हैं।

उदाहरण 1: डिफ़ॉल्ट संदेश के साथ कस्टम त्रुटि

function MyError(message) { 
   this.name = 'CustomError'; 
   this.message = message || 'Error raised with default message'; 
} 
try { 
   throw new MyError(); 
} catch (e) {  
   console.log(e.name);      
   console.log(e.message);  // 'Default Message' 
}

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

CustomError 
Error raised with default message

उदाहरण 2: उपयोगकर्ता द्वारा परिभाषित त्रुटि संदेश के साथ कस्टम त्रुटि

function MyError(message) { 
   this.name = 'CustomError'; 
   this.message = message || 'Default Error Message';  
} try { 
   throw new MyError('Printing Custom Error message'); 
} 
catch (e) { 
   console.log(e.name);      
   console.log(e.message);  
}

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

CustomError 
Printing Custom Error message

ईएस 6 - ऑब्जेक्ट एक्सटेंशन्स

स्ट्रिंग विस्तार

ईएस 6 में स्ट्रिंग ऑब्जेक्ट में जोड़े गए कुछ लोकप्रिय तरीके हैं -

अनु क्रमांक विधि और विवरण
1 str.startsWith (searchString [, स्थिति])

निर्धारित करता है कि एक स्ट्रिंग एक निर्दिष्ट स्ट्रिंग के पात्रों से शुरू होती है या नहीं। सच्चा या झूठा लौटाता है

2 str.endsWith (सर्चस्ट्रिंग [, लंबाई])

निर्धारित करता है कि एक स्ट्रिंग एक निर्दिष्ट स्ट्रिंग के पात्रों के साथ समाप्त होती है या नहीं। सच्चा / झूठा लौटाता है

3 str.includes (searchString [, स्थिति])

निर्धारित करता है कि क्या एक स्ट्रिंग दूसरे स्ट्रिंग के भीतर मिल सकती है

4 str.repeat (संख्या)

एक नई स्ट्रिंग का निर्माण करता है और लौटाता है, जिसमें उस स्ट्रिंग की प्रतियों की निर्दिष्ट संख्या होती है, जिस पर इसे एक साथ मिलाया जाता है

रेगेक्स एक्सटेंशन

एक नियमित अभिव्यक्ति में, उदाहरण के लिए, /[A-Z]/gशुरुआत और अंत / कहा जाता है delimiters। समापन के बाद कुछ भी परिसीमन को कहा जाता हैmodifier। ईएस 6 एक नया संशोधक जोड़ता है/g कहाँ पे g के लिए खड़ा है global। यह केवल एक ही नहीं, एक स्ट्रिंग में पैटर्न के सभी उदाहरणों से मेल खाता है।

उदाहरण

निम्न उदाहरण स्ट्रिंग में सभी ऊपरी-केस वर्णों को खोजता है और लौटाता है।

<script>
   let str = 'JJavascript is Fun to Work , very Fun '
   let regex = /[A-Z]/g // g stands for global matches
   let result = str.match(regex);
   console.log(result)
</script>

उपरोक्त कोड का आउटपुट नीचे दिया गया है -

["J", "J", "F", "W", "F"]

नियमित अभिव्यक्ति खोजें केस-संवेदी हैं। केस-संवेदनशीलता को बंद करने के लिए, का उपयोग करें/i संशोधक।

उदाहरण

निम्नलिखित उदाहरण एक मामले को असंवेदनशील वैश्विक मैच करता है। उदाहरण बदलता हैfun साथ में enjoyable

<script>
   // /gi global match ignore case

   let str = 'Javascript is fun to Work , very Fun '
   let regex = /Fun/gi;
   console.log(str.replace(regex,'enjoyable'));
   console.log(str)
   console.log(str.search(regex))
</script>

उपरोक्त कोड का आउटपुट नीचे दिखाया गया है -

Javascript is enjoyable to Work , very enjoyable
Javascript is fun to Work , very Fun
15

संख्या

कुछ लोकप्रिय तरीके जोड़े गए Number object ES6 में हैं -

अनु क्रमांक विधि और विवरण
1 Number.isFinite (मान)

विधि निर्धारित करती है कि पारित मूल्य एक परिमित संख्या है या नहीं। सच्चा / झूठा लौटाता है।

2 Number.isNaN (मान)

यदि दिया गया मान NaN है और उसका प्रकार संख्या है तो सही है; अन्यथा, असत्य।

3 Number.parseFloat (स्ट्रिंग)

दिए गए मान से एक फ़्लोटिंग-पॉइंट नंबर पार्स किया गया। यदि मान को किसी संख्या में नहीं बदला जा सकता है, तो NaN लौटाया जाता है।

4 नंबर.पारसीआई (स्ट्रिंग, [मूलांक])

विधि एक स्ट्रिंग तर्क देती है और निर्दिष्ट मूलांक या आधार का पूर्णांक लौटाती है।

गणित

कुछ लोकप्रिय तरीके जोड़े गए Math object ES6 में हैं -

अनु क्रमांक विधि और विवरण
1 Math.sign ()

फ़ंक्शन एक संख्या का संकेत देता है, यह दर्शाता है कि संख्या सकारात्मक, नकारात्मक या शून्य है।

2 Math.trunc ()

फ़ंक्शन किसी भी अंश अंकों को हटाकर किसी संख्या का पूर्णांक भाग देता है।

ES6 में ऐरे के तरीके

नीचे दी गई तालिका विवरण के साथ ES6 में विभिन्न सरणी विधियों पर प्रकाश डालती है।

अनु क्रमांक विधि और विवरण
1 copyWithin ()

उथले किसी सरणी के भाग को उसी सरणी में किसी अन्य स्थान पर कॉपी करता है और उसकी लंबाई को संशोधित किए बिना उसे लौटाता है।

2 प्रविष्टियों ()

विधि सरणी में प्रत्येक अनुक्रमणिका के लिए कुंजी / मान जोड़े में एक नया ऐरे Iterator ऑब्जेक्ट देता है।

3 लगता है ()

विधि सरणी में पहले तत्व का मान लौटाता है जो प्रदान किए गए परीक्षण फ़ंक्शन को संतुष्ट करता है। अन्यथा अपरिभाषित लौटा दिया जाता है ।।

4 भरने ()

विधि एक सरणी सूचकांक के सभी तत्वों को एक स्थिर सूचकांक के साथ एक अंत सूचकांक से भरती है। यह संशोधित सरणी देता है।

5 की श्रंखला()

विधि तर्कों की एक परिवर्तनीय संख्या से एक नया ऐरे उदाहरण बनाती है, चाहे संख्याओं या तर्कों की परवाह किए बिना।

6 Array.from ()

विधि एक सरणी से एक उथले प्रतिलिपि बनाता है जैसे या चलने योग्य वस्तु।

वस्तु

ऑब्जेक्ट फ़ंक्शन से संबंधित विधियों को संबंधित विवरण के साथ तालिका में नीचे वर्णित किया गया है।

अनु क्रमांक विधि और विवरण
1 Object.is ()

विधि निर्धारित करती है कि क्या दो मान समान हैं

2 Object.setPrototypeOf ()

विधि किसी निर्दिष्ट ऑब्जेक्ट के प्रोटोटाइप को किसी अन्य ऑब्जेक्ट या नल के लिए सेट करती है।

3 Object.assign ()

विधि का उपयोग एक या एक से अधिक स्रोत वस्तुओं से लक्ष्य वस्तु तक सभी गणना करने योग्य गुणों के मूल्यों को कॉपी करने के लिए किया जाता है। यह लक्ष्य वस्तु को लौटा देगा।

ईएस 6 - रिफलेक्ट एपीआई

ES6 मेटा-प्रोग्रामिंग के आसपास नई विशेषताओं का परिचय देता है जिसमें कार्यक्रम की संरचना का निरीक्षण करना या संशोधित करना, या भाषा में काम करने के तरीके को बदलना शामिल है।

मेटा प्रोग्रामिंग के तीन रूप निम्नलिखित हैं -

  • Introspection- आत्मनिरीक्षण का अर्थ है अपने बारे में जानकारी इकट्ठा करने वाला कार्यक्रम। जावास्क्रिप्ट ऑपरेटरों के कुछ उदाहरण जो आत्मनिरीक्षण के लिए उपयोग किए जाते हैंtypeof, instanceof आदि।

  • Self-modification- स्व-संशोधन से तात्पर्य किसी कार्यक्रम की संरचना को रनटाइम पर संशोधित करना है। इसमें रनटाइम पर नई संपत्तियों तक पहुंच बनाना या बनाना शामिल है। दूसरे शब्दों में, आत्म-संशोधन तब होता है जब कोई कोड स्वयं को संशोधित करता है।

  • Intercession- एक प्रोग्रामिंग भाषा के डिफ़ॉल्ट व्यवहार को संशोधित करने वाले कोड को संदर्भित करता है। रुकावट में प्रोग्रामिंग भाषा के शब्दार्थों को संशोधित करना या रनटाइम में कार्यक्रम में नए निर्माणों को जोड़ना शामिल है।

ईएस 6 रिफ्लेक्ट एप्लिकेशन प्रोग्रामिंग इंटरफेस (रिफ्लेक्ट एपीआई) और प्रॉक्सी एपीआई पेश करता है जो मेटा प्रोग्रामिंग का समर्थन करता है।

रिफ्लैक्ट एपीआई के साथ मेटा प्रोग्रामिंग

ईएस 6 में रिफलेक्ट एपीआई हमें रनटाइम पर किसी प्रोग्राम के क्लासेस, ऑब्जेक्ट्स, प्रॉपर्टीज और तरीकों का निरीक्षण या संशोधन करने की अनुमति देता है। Reflectएपीआई वैश्विक रिफ्लेक्ट ऑब्जेक्ट प्रदान करता है जिसमें स्थैतिक तरीके होते हैं जिनका उपयोग आत्मनिरीक्षण के लिए किया जा सकता है। इन विधियों का उपयोग कोड के बारे में निम्न स्तर की जानकारी खोजने के लिए किया जाता है। रिफ्लेक्ट एपीआई का उपयोग ऑटोमेशन टेस्टिंग फ्रेमवर्क के निर्माण के लिए किया जा सकता है जो रनटाइम के दौरान प्रोग्राम की जांच और आत्मनिरीक्षण करता है।

रिफ्लेक्ट ऑब्जेक्ट के कुछ आमतौर पर उपयोग किए गए तरीके नीचे दिए गए हैं -

अनु क्रमांक विधि और विवरण
1 Reflect.apply ()

आर्ग्स पैरामीटर द्वारा निर्दिष्ट तर्क के साथ एक लक्ष्य फ़ंक्शन को कॉल करता है

2 Reflect.construct ()

एक वर्ग के नए लक्ष्य (... आर्ग्स) को बुलाने के बराबर

3 Reflect.get ()

एक फ़ंक्शन जो गुणों का मान लौटाता है।

4 Reflect.set ()

एक फ़ंक्शन जो गुणों के लिए मान प्रदान करता है। एक बूलियन लौटाता है जो अद्यतन सफल रहा तो सही है।

5 Reflect.has ()

ऑपरेटर में फ़ंक्शन के रूप में। एक बूलियन को इंगित करता है कि क्या एक या विरासत में मिली संपत्ति मौजूद है।

ईएस 6 - प्रॉक्सी एपीआई

ईएस 6 प्रॉक्सिस का उपयोग करके मेटा प्रोग्रामिंग के इंटरसेशन फॉर्म को लागू करता है। ReflectAPI के समान, प्रॉक्सी API ES6 में मेटा प्रोग्रामिंग को लागू करने का एक और तरीका है। मौलिक कार्यों के लिए कस्टम व्यवहार को परिभाषित करने के लिए प्रॉक्सी ऑब्जेक्ट का उपयोग किया जाता है। एक प्रॉक्सी ऑब्जेक्ट असली ऑब्जेक्ट की ओर से कुछ ऑपरेशन करता है।

ES6 परदे के पीछे से संबंधित विभिन्न शब्दावली नीचे दी गई हैं

अनु क्रमांक विधि और विवरण
1

handler

प्लेसहोल्डर ऑब्जेक्ट जिसमें जाल होते हैं

2

traps

संपत्ति पहुंच प्रदान करने वाले तरीके। यह ऑपरेटिंग सिस्टम में जाल की अवधारणा के अनुरूप है

1

target

वह वस्तु जो प्रॉक्सी वर्चुअलाइज करती है। यह अक्सर प्रॉक्सी के लिए स्टोरेज बैकेंड के रूप में उपयोग किया जाता है।

वाक्य - विन्यास

नीचे दिया गया वाक्यविन्यास प्रॉक्सी एपीआई के लिए है, जहां, target किसी भी प्रकार की वस्तु हो सकती है जैसे कि सरणी, फ़ंक्शन या अन्य प्रॉक्सी और handlerएक ऐसी वस्तु है जिसके गुण कार्य हैं। यह प्रॉक्सी के व्यवहार को परिभाषित करता है।

const proxy = new Proxy(target,handler)

हैंडलर तरीके

हैंडलर ऑब्जेक्ट में प्रॉक्सी के लिए जाल होते हैं। सभी जाल वैकल्पिक हैं। यदि एक जाल को परिभाषित नहीं किया गया है, तो डिफ़ॉल्ट व्यवहार लक्ष्य को ऑपरेशन को आगे बढ़ाने के लिए है। कुछ सामान्य हैंडलर विधियां इस प्रकार हैं -

अनु क्रमांक विधि और विवरण
1 handler.apply ()

फ़ंक्शन कॉल के लिए एक जाल।

2 handler.construct ()

नए ऑपरेटर के लिए एक जाल।

3 handler.get ()

संपत्ति मूल्यों को प्राप्त करने के लिए एक जाल।

4 handler.set ()

संपत्ति मूल्यों की स्थापना के लिए एक जाल।

5 handler.has ()

ऑपरेटर के लिए टीए जाल।

ईएस 6 - मान्यताओं

Form validationसामान्य रूप से सर्वर पर उपयोग किया जाता था, जब क्लाइंट ने सभी आवश्यक डेटा दर्ज किए थे और फिर सबमिट बटन दबाया था। यदि क्लाइंट द्वारा दर्ज किया गया डेटा गलत था या बस गायब था, तो सर्वर को क्लाइंट को सभी डेटा वापस भेजना होगा और अनुरोध करना होगा कि फॉर्म को सही जानकारी के साथ फिर से सबमिट किया जाए। यह वास्तव में एक लंबी प्रक्रिया थी जो सर्वर पर बहुत अधिक बोझ डालती थी।

वेब सर्वर पर भेजने से पहले क्लाइंट के कंप्यूटर पर फॉर्म के डेटा को मान्य करने के लिए जावास्क्रिप्ट एक तरीका प्रदान करता है। प्रपत्र सत्यापन आम तौर पर दो कार्य करता है।

  • Basic Validation - सबसे पहले, यह सुनिश्चित करने के लिए फॉर्म को चेक किया जाना चाहिए कि सभी अनिवार्य फ़ील्ड भरे गए हैं। इसके लिए फॉर्म में प्रत्येक फ़ील्ड के माध्यम से एक लूप की आवश्यकता होगी और डेटा की जाँच करें।

  • Data Format Validation- दूसरी बात, जो डेटा दर्ज किया गया है, उसे सही फॉर्म और वैल्यू के लिए चेक करना चाहिए। आपके कोड में डेटा की शुद्धता का परीक्षण करने के लिए उपयुक्त तर्क शामिल होना चाहिए।

उदाहरण

हम सत्यापन की प्रक्रिया को समझने के लिए एक उदाहरण लेंगे। यहाँ HTML प्रारूप में एक सरल रूप है।

<html>
 
   <head> 
      <title>Form Validation</title> 
      <script type = "text/javascript"> 
         <!--  
            // Form validation code will come here.  
            //
         --> 
      </script> 
   </head> 

   <body> 
      <form action = "/cgi-bin/test.cgi" name = "myForm" onsubmit = "return(validate());"> 
         <table cellspacing = "2" cellpadding = "2" border = "1"> 
            <tr> 
               <td align = "right">Name</td> 
               <td><input type = "text" name = "Name" /></td>
            </tr> 
            <tr> 
               <td align = "right">EMail</td> 
               <td><input type = "text" name = "EMail" /></td> 
            </tr> 
            <tr> 
               <td align = "right">Zip Code</td> 
               <td><input type = "text" name = "Zip" /></td> 
            </tr> 
            <tr> 
               <td align = "right">Country</td> 
               <td> 
                  <select name = "Country"> 
                     <option value = "-1" selected>[choose yours]</option> 
                     <option value = "1">USA</option> 
                     <option value = "2">UK</option> 
                     <option value = "3">INDIA</option> 
                  </select> 
               </td> 
            </tr> 
            <tr> 
               <td align = "right"></td> 
               <td><input type = "submit" value = "Submit" /></td> 
            </tr> 
         </table> 
      </form> 
   </body> 
   
</html>

उत्पादन

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

मूल रूप मान्यता

पहले देखते हैं कि मूल रूप सत्यापन कैसे किया जाता है। उपरोक्त रूप में, हम बुला रहे हैंvalidate() डेटा को कब सत्यापित करें onsubmitघटना घट रही है। निम्न कोड इस मान्य () फ़ंक्शन के कार्यान्वयन को दर्शाता है।

<script type = "text/javascript"> 
   <!--  
      // Form validation code will come here. function validate() {    
         if( document.myForm.Name.value == "" ) {  
            alert( "Please provide your name!" );      
            document.myForm.Name.focus() ;      
            return false;  
         }  
         if( document.myForm.EMail.value == "" ) {  
            alert( "Please provide your Email!" );      
            document.myForm.EMail.focus() ;      
            return false; 
         }  
         if( document.myForm.Zip.value == "" ||            
         isNaN( document.myForm.Zip.value ) ||            
         document.myForm.Zip.value.length != 5 ) {  
            alert( "Please provide a zip in the format #####." );      
            document.myForm.Zip.focus() ;      
            return false;  
         }  
         if( document.myForm.Country.value == "-1" ) {  
            alert( "Please provide your country!" );      
            return false;  
         }  
         return( true );  
      }  
      //
   --> 
</script>

डेटा प्रारूप सत्यापन

अब हम देखेंगे कि वेब सर्वर पर सबमिट करने से पहले हम अपने दर्ज किए गए फॉर्म डेटा को कैसे मान्य कर सकते हैं।

निम्न उदाहरण दिखाता है कि दर्ज किए गए ईमेल पते को कैसे मान्य किया जाए। ईमेल पते में कम से कम '@' चिह्न और एक डॉट (।) होना चाहिए। इसके अलावा, '@' ईमेल पते का पहला वर्ण नहीं होना चाहिए, और अंतिम बिंदु '@' चिह्न के बाद कम से कम एक वर्ण होना चाहिए

उदाहरण

ईमेल सत्यापन के लिए निम्न कोड का प्रयास करें।

<script type = "text/javascript"> 
   <!--  
      function validateEmail() { 
         var emailID = document.myForm.EMail.value;    
         atpos = emailID.indexOf("@");    
         dotpos = emailID.lastIndexOf(".");    
         
         if (atpos < 1 || ( dotpos - atpos < 2 )) {       
            alert("Please enter correct email ID")         
            document.myForm.EMail.focus() ;         
            return false;    
         }     
         return( true );  
      } 
      //
   --< 
</script>

ईएस 6 - एनीमेशन

आप एक जटिल एनीमेशन बनाने के लिए जावास्क्रिप्ट का उपयोग कर सकते हैं, लेकिन निम्नलिखित तत्वों तक सीमित नहीं हैं -

  • Fireworks
  • फीका असर
  • रोल-इन या रोल-आउट
  • पेज-इन या पेज-आउट
  • वस्तु की चाल

इस अध्याय में, हम देखेंगे कि एनीमेशन बनाने के लिए जावास्क्रिप्ट का उपयोग कैसे करें।

किसी तार्किक समीकरण या फ़ंक्शन द्वारा निर्धारित पैटर्न के कुछ प्रकार के अनुसार जावास्क्रिप्ट का उपयोग पृष्ठ के चारों ओर कई DOM तत्वों (<img />, <div>, या किसी अन्य HTML तत्व) को स्थानांतरित करने के लिए किया जा सकता है।

जावास्क्रिप्ट अक्सर एनीमेशन कार्यक्रमों में उपयोग किए जाने वाले निम्नलिखित कार्य प्रदान करता है।

  • setTimeout(फ़ंक्शन, अवधि) - यह फ़ंक्शन अब से अवधि मिलीसेकंड के बाद फ़ंक्शन को कॉल करता है।

  • setInterval(फ़ंक्शन, अवधि) - यह फ़ंक्शन हर अवधि मिलीसेकंड के बाद फ़ंक्शन को कॉल करता है।

  • clearTimeout(setTimeout_variable) - यह फ़ंक्शन सेटटाइमआउट () फ़ंक्शन द्वारा सेट किए गए किसी भी टाइमर को साफ़ करता है।

JavaScript किसी DOM ऑब्जेक्ट की कई विशेषताओं को स्क्रीन पर उसकी स्थिति सहित सेट कर सकती है। आप किसी वस्तु के शीर्ष और बाईं विशेषता को स्क्रीन पर कहीं भी रख सकते हैं। निम्नलिखित के लिए सिंटैक्स है।

// Set distance from left edge of the screen.  
object.style.left = distance in pixels or points;    
or  
// Set distance from top edge of the screen.  
object.style.top = distance in pixels or points;

मैनुअल एनीमेशन

तो आइए DOM ऑब्जेक्ट प्रॉपर्टीज़ और जावास्क्रिप्ट फ़ंक्शंस का उपयोग करके एक सरल एनीमेशन लागू करें। निम्न सूची में भिन्न DOM विधियाँ हैं।

  • हम जावास्क्रिप्ट फ़ंक्शन का उपयोग कर रहे हैं getElementById() DOM ऑब्जेक्ट प्राप्त करना और फिर इसे एक ग्लोबल वैरिएबल में असाइन करना imgObj

  • हमने एक आरंभीकरण फ़ंक्शन को परिभाषित किया है init() imgObj को शुरू करने के लिए जहां हमने इसकी स्थिति और बाईं विशेषताओं को निर्धारित किया है।

  • विंडो लोड के समय हम इनिशियलाइज़ेशन फंक्शन कह रहे हैं।

  • हम बुला रहे हैं moveRight()10 पिक्सेल से बाईं दूरी बढ़ाने के लिए कार्य करते हैं। आप इसे बाईं ओर ले जाने के लिए एक ऋणात्मक मान पर भी सेट कर सकते हैं।

उदाहरण

निम्न उदाहरण का प्रयास करें

<html> 
   <head> 
      <title>JavaScript Animation</title> 
      <script type = "text/javascript"> 
         <!--  
            var imgObj = null; function init(){  
               imgObj = document.getElementById('myImage');
               imgObj.style.position = 'relative';     
               imgObj.style.left = '0px';   
            }     
            function moveRight(){  
               imgObj.style.left = parseInt(
               imgObj.style.left) + 10 + 'px';  
            }  
            window.onload = init;  
            //
         --> 
      </script> 
   </head> 
   
   <body> 
      <form> 
         <img id = "myImage" src = "/images/html.gif" /> 
         <p>Click button below to move the image to right</p> 
         <input type = "button" value = "Click Me" onclick = "moveRight();" /> 
      </form>
   </body>
   
</html>

स्वचालित एनीमेशन

उपरोक्त उदाहरण में, हमने देखा कि हर क्लिक के साथ दाईं ओर एक छवि कैसे चलती है। हम जावास्क्रिप्ट फ़ंक्शन का उपयोग करके इस प्रक्रिया को स्वचालित कर सकते हैंsetTimeout() निम्नलिखित नुसार।

यहाँ हमने और विधियाँ जोड़ी हैं। तो, आइए देखें कि यहां क्या नया है।

  • moveRight() फंक्शन imgObj की स्थिति सेट करने के लिए सेटटाइमआउट () फ़ंक्शन कह रहा है।

  • हमने एक नया फंक्शन जोड़ा है stop() सेटटाइमआउट () फ़ंक्शन द्वारा टाइमर सेट को साफ़ करने और ऑब्जेक्ट को अपने प्रारंभिक स्थान पर सेट करने के लिए।

उदाहरण

निम्न उदाहरण कोड का प्रयास करें।

<html> 
   <head> 
      <title>JavaScript Animation</title> 
      <script type = "text/javascript"> 
         <!--  
            var imgObj = null; var animate ; function init(){  
               imgObj = document.getElementById('myImage');     
               imgObj.style.position = 'relative';    
               imgObj.style.left = '0px'; 
            }  
            function moveRight(){  
               imgObj.style.left = parseInt(imgObj.style.left) + 10 + 'px';    
               animate = setTimeout(moveRight,20); 
               // call moveRight in 20msec  
            }  
            function stop() {     
               clearTimeout(animate);    
               imgObj.style.left = '0px';   
            }  
            window.onload = init;  
            //
         --> 
      </script> 
   </head> 

   <body> 
      <form> 
         <img id = "myImage" src = "/images/html.gif" /> 
         <p>Click the buttons below to handle animation</p> 
         <input type="button" value="Start" onclick = "moveRight();" /> 
         <input type = "button" value="Stop" onclick = "stop();" /> 
      </form>    
   </body> 
</html>

एक माउस घटना के साथ रोलओवर

यहां एक सरल उदाहरण है जो माउस इवेंट के साथ छवि रोलओवर दिखा रहा है।

आइए देखें कि हम निम्नलिखित उदाहरण में क्या उपयोग कर रहे हैं -

  • इस पृष्ठ को लोड करने के समय, 'if' स्टेटमेंट इमेज ऑब्जेक्ट के अस्तित्व की जांच करता है। यदि छवि ऑब्जेक्ट अनुपलब्ध है, तो यह ब्लॉक निष्पादित नहीं किया जाएगा।

  • Image() कंस्ट्रक्टर एक नई छवि ऑब्जेक्ट बनाता और प्री लोड करता है image1

  • src प्रॉपर्टी को एक्सटर्नल इमेज फाइल का नाम असाइन किया जाता है /images/html.gif

  • इसी तरह, हमने बनाया है image2 ऑब्जेक्ट और असाइन किया गया /images/http.gif इस वस्तु में।

  • #(हैश मार्क) लिंक को निष्क्रिय कर देता है ताकि क्लिक करने पर ब्राउज़र URL पर जाने की कोशिश न करे। यह लिंक एक छवि है।

  • onMouseOver जब उपयोगकर्ता का माउस लिंक पर चला जाता है, और onMouseOut जब उपयोगकर्ता का माउस लिंक (छवि) से दूर चला जाता है तो ईवेंट हैंडलर चालू हो जाता है।

  • जब माउस छवि पर चला जाता है, तो HTTP छवि पहली छवि से दूसरे एक में बदल जाती है। जब माउस को छवि से दूर ले जाया जाता है, तो मूल छवि प्रदर्शित होती है।

  • जब माउस को लिंक से दूर ले जाया जाता है, तो प्रारंभिक छवि html.gif स्क्रीन पर फिर से दिखाई देगा।

<html> 
   <head> 
      <title>Rollover with a Mouse Events</title> 
      <script type = "text/javascript"> 
         <!--  
            if(document.images) {  
               var image1 = new Image();       
               // Preload an image image1.src = "/images/html.gif";  
                  
               var image2 = new Image();       
               // Preload second image image2.src = "/images/http.gif";  
            }  
            //
         -->
      </script> 
   </head> 

   <body> 
      <p>Move your mouse over the image to see the result</p>
      <a href = "#" onMouseOver = "document.myImage.src = image2.src;"      
         onMouseOut = "document.myImage.src = image1.src;"> 
         <img name = "myImage" src = "/images/html.gif" /> 
      </a> 
   </body>
   
</html>

ईएस 6 - मल्टीमीडिया

जावास्क्रिप्ट नेविगेटर ऑब्जेक्ट में एक चाइल्ड ऑब्जेक्ट कहा जाता है plugins। यह ऑब्जेक्ट एक सरणी है, जिसमें ब्राउज़र पर इंस्टॉल किए गए प्रत्येक प्लग-इन के लिए एक प्रविष्टि है। navigator.plugins ऑब्जेक्ट केवल नेटस्केप, फ़ायरफ़ॉक्स और मोज़िला द्वारा समर्थित है।

उदाहरण

निम्न उदाहरण दिखाता है कि आपके ब्राउज़र में स्थापित सभी प्लग-इन को कैसे सूचीबद्ध किया जाए।

<html> 
   <head> 
      <title>List of Plug-Ins</title> 
   </head> 
   <body> 
      <table border = "1"> 
         <tr>
            <th>Plug-in Name</th>
            <th>Filename</th>
            <th>Description</th>
         </tr> 
         <script LANGUAGE = "JavaScript" type = "text/javascript"> 
            for (i = 0; i<navigator.plugins.length; i++) {    
               document.write("<tr><td>");  
               document.write(navigator.plugins[i].name);    
               document.write("</td><td>");  
               document.write(navigator.plugins[i].filename); 
               document.write("</td><td>");  
               document.write(navigator.plugins[i].description);    
               document.write("</td></tr>");  
            }  
         </script> 
      </table> 
   </body>
   
</html>

उत्पादन

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

प्लगइन्स के लिए जाँच कर रहा है

प्रत्येक प्लग-इन सरणी में एक प्रविष्टि है। प्रत्येक प्रविष्टि में निम्नलिखित गुण हैं -

  • name - प्लग-इन का नाम।

  • filename - निष्पादन योग्य फ़ाइल जिसे प्लग-इन स्थापित करने के लिए लोड किया गया था।

  • description - डेवलपर द्वारा आपूर्ति की गई प्लग-इन का विवरण।

  • mimeTypes - प्लगइन द्वारा समर्थित प्रत्येक MIME प्रकार के लिए एक प्रविष्टि के साथ एक सरणी।

आप इन संपत्तियों का उपयोग स्क्रिप्ट में स्थापित प्लग-इन का पता लगाने के लिए कर सकते हैं, और फिर जावास्क्रिप्ट का उपयोग करके, आप उपयुक्त मल्टीमीडिया फ़ाइल खेल सकते हैं। निम्नलिखित कोड पर एक नज़र डालें।

<html> 
   <head> 
      <title>Using Plug-Ins</title> 
   </head> 
   
   <body> 
      <script language = "JavaScript" type = "text/javascript"> 
         media  =  navigator.mimeTypes["video/quicktime"]; if (media) {  
            document.write("<embed src = 'quick.mov' height = 100 width = 100>");  
         } else {  
            document.write("<img src = 'quick.gif' height = 100 width = 100>");  
         }  
      </script> 
   </body>
</html>

Note - यहां हम HTML का उपयोग कर रहे हैं <embed> tag मल्टीमीडिया फ़ाइल एम्बेड करने के लिए।

मल्टीमीडिया पर नियंत्रण

आइए एक वास्तविक उदाहरण लेते हैं जो लगभग सभी ब्राउज़रों में काम करता है।

<html> 
   <head> 
      <title>Using Embeded Object</title> 
      
      <script type = "text/javascript"> 
         <!--  
            function play() {  
               if (!document.demo.IsPlaying()) {      
                  document.demo.Play();  
               }  
            }  
            function stop() {  
               if (document.demo.IsPlaying()){      
                  document.demo.StopPlay();  
               }  
            }  
            function rewind() { 
               if (document.demo.IsPlaying()){      
                  document.demo.StopPlay();  
               }  
               document.demo.Rewind();  
            } 
            //
         --> 
      </script> 
   </head> 
   <body> 
      <embed id = "demo" name = "demo"
         src = "http://www.amrood.com/games/kumite.swf" 
         width = "318" height = "300" play = "false" loop = "false"     
         pluginspage = "http://www.macromedia.com/go/getflashplayer"     
         swliveconnect = "true"> 
      </embed> 
      
      <form name = "form" id = "form" action = "#" method = "get"> 
         <input type = "button" value = "Start" onclick = "play();" /> 
         <input type = "button" value = "Stop" onclick = "stop();" /> 
         <input type = "button" value = "Rewind" onclick = "rewind();" /> 
      </form>
   </body> 
</html>

ईएस 6 - डिबगिंग

हर अब और फिर, डेवलपर्स कोडिंग करते समय गलतियां करते हैं। किसी प्रोग्राम या स्क्रिप्ट की गलती को स्क्रिप्ट के रूप में संदर्भित किया जाता हैbug

कीड़े को खोजने और ठीक करने की प्रक्रिया को कहा जाता है debuggingऔर विकास प्रक्रिया का एक सामान्य हिस्सा है। इस अध्याय में उन उपकरणों और तकनीकों को शामिल किया गया है जो आपको डिबगिंग कार्यों में मदद कर सकती हैं।

IE में त्रुटि संदेश

त्रुटियों को ट्रैक करने का सबसे मूल तरीका आपके ब्राउज़र में त्रुटि जानकारी को चालू करना है। डिफ़ॉल्ट रूप से, इंटरनेट एक्सप्लोरर स्थिति पट्टी में एक त्रुटि आइकन दिखाता है जब पृष्ठ पर कोई त्रुटि होती है।

इस आइकन पर डबल-क्लिक करना आपको एक डायलॉग बॉक्स में ले जाता है, जो विशिष्ट त्रुटि के बारे में जानकारी देता है।

चूँकि इस आइकन को अनदेखा करना आसान है, जब भी कोई त्रुटि होती है तो Internet Explorer आपको स्वतः त्रुटि डायलॉग बॉक्स दिखाने का विकल्प देता है।

इस विकल्प को सक्षम करने के लिए, का चयन करें Tools → Internet Options → Advanced tab और फिर अंत में जाँच करें "Display a NotificationaboutEvery Script Error“बॉक्स विकल्प जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है।

फ़ायरफ़ॉक्स या मोज़िला में त्रुटि संदेश

फ़ायरफ़ॉक्स, नेटस्केप, और मोज़िला जैसे अन्य ब्राउज़र एक विशेष विंडो में त्रुटि संदेश भेजते हैं जिन्हें कहा जाता है JavaScript Console या Error Console। कंसोल देखने के लिए, चयन करेंTools → Error Console or Web Development

दुर्भाग्यवश, चूंकि ये ब्राउज़र त्रुटि होने पर कोई दृश्य संकेत नहीं देते हैं, इसलिए आपको कंसोल को खुला रखना चाहिए और त्रुटियों के लिए देखना होगा क्योंकि आपकी स्क्रिप्ट निष्पादित होती है।

त्रुटि सूचनाएँ

कंसोल या इंटरनेट एक्सप्लोरर संवाद बॉक्स के माध्यम से दिखाई देने वाली त्रुटि सूचनाएं सिंटैक्स और रनटाइम त्रुटियों दोनों का परिणाम हैं। इन त्रुटि सूचनाओं में वह पंक्ति संख्या शामिल होती है जिस पर त्रुटि हुई।

यदि आप फ़ायरफ़ॉक्स का उपयोग कर रहे हैं, तो आप त्रुटि कंसोल में उपलब्ध त्रुटि पर क्लिक कर सकते हैं जिसमें त्रुटि होने वाली स्क्रिप्ट में सटीक लाइन पर जा सकते हैं।

एक स्क्रिप्ट डिबगिंग

आपके जावास्क्रिप्ट को डीबग करने के विभिन्न तरीके हैं। इसके कुछ तरीके निम्नलिखित हैं।

एक जावास्क्रिप्ट वैध का प्रयोग करें

अजीब कीड़े के लिए अपने जावास्क्रिप्ट कोड की जांच करने का एक तरीका यह है कि इसे एक प्रोग्राम के माध्यम से चलाया जाए जो यह सुनिश्चित करता है कि यह मान्य है और यह भाषा के आधिकारिक वाक्यविन्यास नियमों का पालन करता है। इन कार्यक्रमों को कहा जाता हैvalidating parsers या संक्षिप्त के लिए सिर्फ सत्यापनकर्ता, और अक्सर वाणिज्यिक HTML और जावास्क्रिप्ट संपादकों के साथ आते हैं।

जावास्क्रिप्ट के लिए सबसे सुविधाजनक सत्यापनकर्ता डगलस क्रॉफोर्ड की जावास्क्रिप्ट लिंट है, जो डगलस क्रॉकफोर्ड के जावास्क्रिप्ट लिंट पर मुफ्त में उपलब्ध है।

बस वेब पेज पर जाएँ, अपने जावास्क्रिप्ट (केवल जावास्क्रिप्ट) कोड को दिए गए पाठ क्षेत्र में पेस्ट करें, और क्लिक करें jslintबटन। यह प्रोग्राम आपके जावास्क्रिप्ट कोड के माध्यम से पार्स करेगा, यह सुनिश्चित करते हुए कि सभी चर और फ़ंक्शन परिभाषा सही सिंटैक्स का पालन करते हैं। यह जावास्क्रिप्ट स्टेटमेंट की भी जांच करेगा, जैसे कि यदि और जबकि, यह सुनिश्चित करने के लिए कि वे सही प्रारूप का भी पालन करते हैं।

अपने प्रोग्राम में डिबगिंग कोड जोड़ें

आप उपयोग कर सकते हैं alert() या document.write()आपके प्रोग्राम में आपके कोड को डीबग करने के तरीके। उदाहरण के लिए, आप कुछ इस प्रकार लिख सकते हैं -

var debugging = true; var whichImage = "widget"; 
if( debugging )  
   alert( "Calls swapImage() with argument: " + whichImage ); 
   var swapStatus = swapImage( whichImage ); 
if( debugging )  
alert( "Exits swapImage() with swapStatus=" + swapStatus );

अलर्ट की सामग्री और क्रम की जांच करके (जैसा कि वे दिखाई देते हैं, आप अपने कार्यक्रम के स्वास्थ्य की जांच बहुत आसानी से कर सकते हैं।

एक जावास्क्रिप्ट डीबगर का उपयोग करें

debuggerएक प्रोग्रामर है जो प्रोग्रामर के नियंत्रण में स्क्रिप्ट निष्पादन के सभी पहलुओं को रखता है। डीबगर एक स्क्रिप्ट के माध्यम से स्क्रिप्ट की स्थिति पर ठीक-ठीक नियंत्रण प्रदान करते हैं जो आपको मूल्यों के परीक्षण और सेट करने के साथ-साथ निष्पादन के प्रवाह को नियंत्रित करने की अनुमति देता है।

एक बार जब एक स्क्रिप्ट को डिबगर में लोड किया जाता है, तो इसे एक बार में एक पंक्ति में चलाया जा सकता है या कुछ टूटने पर रुकने का निर्देश दिया जा सकता है। एक बार जब निष्पादन रोक दिया जाता है, तो प्रोग्रामर स्क्रिप्ट की स्थिति और उसके चर की जांच कर सकता है ताकि यह निर्धारित किया जा सके कि कुछ गड़बड़ है। आप उनके मूल्यों में परिवर्तन के लिए चर भी देख सकते हैं।

मोज़िला और नेटस्केप ब्राउज़र दोनों के लिए मोज़िला जावास्क्रिप्ट डीबगर (कोड-नाम वेंकमैन) का नवीनतम संस्करण - www.hacksrus.com/~ginda/venkman से डाउनलोड किया जा सकता है ।

डेवलपर्स के लिए उपयोगी टिप्स

अपनी स्क्रिप्ट में त्रुटियों की संख्या को कम करने और डिबगिंग प्रक्रिया को सरल बनाने के लिए आप निम्नलिखित युक्तियों को ध्यान में रख सकते हैं -

  • टिप्पणियों का भरपूर उपयोग करें। टिप्पणियाँ आपको यह समझाने में सक्षम करती हैं कि आपने स्क्रिप्ट को जिस तरह से लिखा था और विशेष रूप से कोड के कठिन वर्गों को समझाने के लिए लिखा था।

  • अपने कोड को पढ़ने में आसान बनाने के लिए हमेशा इंडेंटेशन का उपयोग करें। इंडेंटिंग स्टेटमेंट आपके लिए शुरुआत और समाप्ति टैग, घुंघराले ब्रेसिज़ और अन्य HTML और स्क्रिप्ट तत्वों को मेल करना भी आसान बनाता है।

  • मॉड्यूलर कोड लिखें। जब भी संभव हो, अपने बयानों को फ़ंक्शन में समूहित करें। फ़ंक्शंस आपको समूह से संबंधित कथन, और परीक्षण के साथ-साथ कम से कम प्रयास के साथ कोड के पुन: उपयोग भागों की जांच करने देते हैं।

  • जिस तरह से आप अपने चर और कार्यों का नाम देते हैं, उसके अनुरूप बनें। उन नामों का उपयोग करने का प्रयास करें जो लंबे समय तक सार्थक रहें और जो चर या फ़ंक्शन के उद्देश्य का वर्णन करें।

  • चर और कार्यों का नामकरण करते समय लगातार सिंटैक्स का उपयोग करें। दूसरे शब्दों में, उन्हें सभी लोअरकेस या सभी अपरकेस रखें; यदि आप कैमल-बैक नोटेशन पसंद करते हैं, तो इसका लगातार उपयोग करें।

  • एक मॉड्यूलर फैशन में लंबी स्क्रिप्ट का परीक्षण करें। दूसरे शब्दों में, इसके किसी भी भाग का परीक्षण करने से पहले पूरी स्क्रिप्ट लिखने की कोशिश न करें। एक टुकड़ा लिखें और इसे कोड के अगले हिस्से को जोड़ने से पहले काम करने के लिए प्राप्त करें।

  • वर्णनात्मक चर और फ़ंक्शन नामों का उपयोग करें और एकल वर्ण नामों का उपयोग करने से बचें।

  • अपने उद्धरण चिह्न देखें। याद रखें कि उद्धरण चिह्नों का उपयोग तारों के चारों ओर जोड़े में किया जाता है और यह कि दोनों उद्धरण चिह्न एक ही शैली के होने चाहिए (या तो एकल या दोहरे)।

  • अपने बराबर के संकेत देखें। तुलना उद्देश्य के लिए आपको एक भी = का उपयोग नहीं करना चाहिए।

  • स्पष्ट रूप से चर का स्पष्ट रूप से उपयोग करें var कीवर्ड।

Node.js के साथ डिबगिंग

Node.js में एक पूर्ण विशेषताओं वाली डीबगिंग सुविधा शामिल है। इसका उपयोग करने के लिए, Node.js को डीबग तर्क के साथ शुरू करें और स्क्रिप्ट को डीबग करने के लिए पथ के साथ।

node debug test.js

एक संकेत बताता है कि डिबगर सफलतापूर्वक शुरू हो गया है।

निर्दिष्ट स्थान पर एक ब्रेकपॉइंट लगाने के लिए, डिबगर को स्रोत कोड में कॉल करें जैसा कि निम्नलिखित कोड में दिखाया गया है।

// myscript.js 
x = 5; 
setTimeout(() => { 
   debugger; 
   console.log('world'); 
}, 1000); 
console.log('hello');

निम्नलिखित चरण कमांड का एक सेट है जिसका उपयोग नोड के साथ किया जा सकता है।

अनु क्रमांक स्टेपिंग कमांड और विवरण
1

cont,c

जारी रखें

2

next,n

आगे

3

step,s

अंदर आएं

4

out,o

बाहर कदम

5

pause

कोड रोकें। डेवलपर टूल में ठहराव के समान

नोड की डिबगिंग कमांड की पूरी सूची यहां पाई जा सकती है - https://nodejs.org/api/debugger.html।

विजुअल स्टूडियो कोड और डीबगिंग

विज़ुअल स्टूडियो कोड की प्रमुख विशेषताओं में से एक Node.js रनटाइम के लिए इन-बिल्ट डीबगिंग समर्थन है। अन्य भाषाओं में कोड डीबग करने के लिए, यह डीबगर एक्सटेंशन प्रदान करता है।

डीबगर सुविधाओं की एक बहुतायत प्रदान करता है जो हमें कॉन्फ़िगरेशन फ़ाइलों को लॉन्च करने, लागू करने / हटाने / अक्षम करने और ब्रेकप्वाइंट, चर को सक्षम करने, या डेटा निरीक्षण को सक्षम करने आदि की अनुमति देता है।

VS कोड का उपयोग करके डिबगिंग पर एक विस्तृत गाइड यहां पाया जा सकता है - https://code.visualstudio.com/docs/editor/debugging

ईएस 6 - छवि मानचित्र

क्लाइंट-साइड इमेज मैप बनाने के लिए आप जावास्क्रिप्ट का उपयोग कर सकते हैं। क्लाइंट-साइड छवि नक्शे के लिए usemap विशेषता द्वारा सक्षम हैं<img /> टैग और विशेष <मानचित्र> द्वारा परिभाषित और <area> एक्सटेंशन टैग।

नक्शा बनाने जा रही छवि को <img /> तत्व के रूप में सामान्य रूप से उपयोग करके पृष्ठ में डाला गया है, सिवाय इसके कि यह usemap नामक एक अतिरिक्त विशेषता रखता है। का मूल्यusemap विशेषता <मानचित्र> तत्व पर नाम विशेषता का मूल्य है, जिसे आप एक पाउंड या एक हैड चिह्न से पहले मिलने वाले हैं।

<मानचित्र> तत्व वास्तव में छवि के लिए मानचित्र बनाता है और आमतौर पर <img /> तत्व के बाद सीधे अनुसरण करता है। यह <क्षेत्र /> तत्वों के लिए एक कंटेनर के रूप में कार्य करता है जो वास्तव में क्लिक करने योग्य हॉटस्पॉट को परिभाषित करता है। <मानचित्र> तत्व केवल एक विशेषता, नाम विशेषता, जो कि मानचित्र की पहचान करने वाला नाम है। यह है कि <img /> तत्व जानता है कि किस <map> तत्व का उपयोग करना है।

<क्षेत्र> तत्व आकार और निर्देशांक निर्दिष्ट करता है जो प्रत्येक क्लिक करने योग्य हॉटस्पॉट की सीमाओं को परिभाषित करता है।

माउस के किसी छवि के विभिन्न भागों में ले जाने पर निम्न कोड टेक्स्ट बॉक्स में एक संदेश का उत्पादन करने के लिए इमेजमैप और जावास्क्रिप्ट को जोड़ता है।

<html> 
   <head> 
      <title>Using JavaScript Image Map</title>
      
      <script type="text/javascript"> 
         <!--  
            function showTutorial(name) {  
               document.myform.stage.value = name  
            }  
            //
         --> 
      </script> 
   </head> 

   <body> 
      <form name = "myform"> 
         <input type = "text" name = "stage" size = "20" /> 
      </form> 
      
      <!-- Create  Mappings --> 
      <img src = "//images/usemap.gif" alt = "HTML Map" 
         border = "0" usemap = "#tutorials"/> 
      <map name = "tutorials"> 
         <area shape = "poly" 
            coords = "74,0,113,29,98,72,52,72,38,27" 
            href = "/perl/index.htm" alt = "Perl Tutorial" 
            target = "_self" 
            onMouseOver = "showTutorial('perl')" 
            onMouseOut = "showTutorial('')"/>
         <area shape = "rect"   
            coords = "22,83,126,125"  
            href = "/html/index.htm" alt = "HTML Tutorial" target = "_self"   
            onMouseOver = "showTutorial('html')"         
            onMouseOut = "showTutorial('')"/>  
         <area shape = "circle"  coords = "73,168,32"  
            href = "/php/index.htm" alt = "PHP Tutorial" target = "_self"   
            onMouseOver = "showTutorial('php')"       
            onMouseOut = "showTutorial('')"/> 
      </map> 
   </body>
   
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है। आप छवि ऑब्जेक्ट पर माउस कर्सर रखकर मानचित्र अवधारणा को महसूस कर सकते हैं।

ईएस 6 - ब्राउज़र

विभिन्न ब्राउज़रों के बीच के अंतरों को समझना महत्वपूर्ण है ताकि जिस तरह से यह अपेक्षित है, प्रत्येक को संभाल सके। इसलिए यह जानना महत्वपूर्ण है कि आपका वेब पेज किस ब्राउज़र में चल रहा है। ब्राउज़र के बारे में जानकारी प्राप्त करने के लिए आपका वेबपृष्ठ वर्तमान में चल रहा है, अंतर्निहित नेविगेटर ऑब्जेक्ट का उपयोग करें।

नेविगेटर गुण

कई नेविगेटर संबंधित गुण हैं जिन्हें आप अपने वेबपेज में उपयोग कर सकते हैं। निम्नलिखित नामों और उनके विवरण की एक सूची है।

अनु क्रमांक संपत्ति विवरण
1

appCodeName

यह गुण एक स्ट्रिंग है जिसमें ब्राउज़र का कोड नाम, नेटस्केप के लिए नेटस्केप और इंटरनेट एक्सप्लोरर के लिए माइक्रोसॉफ्ट इंटरनेट एक्सप्लोरर शामिल है।

2

appVersion

यह संपत्ति एक स्ट्रिंग है जिसमें ब्राउज़र के संस्करण के साथ-साथ अन्य उपयोगी जानकारी जैसे कि इसकी भाषा और संगतता शामिल है।

3

language

इस संपत्ति में उस भाषा के लिए दो-अक्षर का संक्षिप्त नाम है जो ब्राउज़र द्वारा उपयोग किया जाता है। नेटस्केप केवल।

4

mimTypes[]

यह गुण एक ऐसा सरणी है जिसमें क्लाइंट द्वारा समर्थित सभी MIME प्रकार शामिल हैं। नेटस्केप केवल।

5

platform[]

यह संपत्ति एक स्ट्रिंग है जिसमें वह प्लेटफ़ॉर्म है जिसके लिए ब्राउज़र संकलित किया गया था। 32-बिट विंडोज ऑपरेटिंग सिस्टम के लिए "Win32"।

6

plugins[]

यह गुण एक ऐसा सरणी है जिसमें सभी प्लग-इन हैं जो क्लाइंट पर इंस्टॉल किए गए हैं। नेटस्केप केवल।

7

userAgent[]

यह संपत्ति एक स्ट्रिंग है जिसमें ब्राउज़र का कोड नाम और संस्करण शामिल है। यह मान क्लाइंट की पहचान करने के लिए मूल सर्वर पर भेजा जाता है।

नेविगेटर विधियाँ

कई नेविगेटर-विशिष्ट विधियाँ हैं। यहाँ उनके नाम और विवरण की एक सूची दी गई है।

अनु क्रमांक तरीके और विवरण
1

javaEnabled()

यह विधि निर्धारित करती है कि जावास्क्रिप्ट क्लाइंट में सक्षम है या नहीं। यदि जावास्क्रिप्ट सक्षम है, यह विधि सही है; अन्यथा, यह गलत है।

2

plugings.refresh

यह विधि नव स्थापित प्लग-इन उपलब्ध कराती है और सभी नए प्लग-इन नामों के साथ प्लगइन्स सरणी को पॉप्युलेट करती है। नेटस्केप केवल

3

preference(name,value)

यह विधि एक हस्ताक्षरित स्क्रिप्ट को कुछ नेटस्केप वरीयताओं को प्राप्त करने और सेट करने की अनुमति देती है। यदि दूसरा पैरामीटर छोड़ा गया है, तो यह विधि निर्दिष्ट वरीयता का मान लौटाएगी; अन्यथा, यह मान सेट करता है। नेटस्केप केवल

4

taintEnabled()

यदि डेटा टेनिंग सक्षम है तो यह विधि सही है; गलत है अन्यथा

ब्राउज़र का पता लगाना

निम्न जावास्क्रिप्ट कोड का उपयोग ब्राउज़र के नाम का पता लगाने के लिए किया जा सकता है और फिर तदनुसार एक HTML पेज को उपयोगकर्ता को परोसा जा सकता है।

<html> 
   <head> 
      <title>Browser Detection Example</title> 
   </head> 

   <body> 
      <script type = "text/javascript"> 
         <!--  
            var userAgent   = navigator.userAgent;  
            var opera       = (userAgent.indexOf('Opera') 
            ! = -1); var ie          = (userAgent.indexOf('MSIE') 
            != -1); var gecko        = (userAgent.indexOf('Gecko') 
            ! = -1); var netscape    = (userAgent.indexOf('Mozilla') 
            ! = -1); var version     = navigator.appVersion;  

            if (opera) {  
               document.write("Opera based browser");    
               // Keep your opera specific URL here.  
            } else if (gecko) {
               document.write("Mozilla based browser");   
               // Keep your gecko specific URL here.  
            } else if (ie) {   
               document.write("IE based browser");    
               // Keep your IE specific URL here.  
            } else if (netscape) {  
               document.write("Netscape based browser");    
               // Keep your Netscape specific URL here.  
            } else {  
               document.write("Unknown browser");  
            }   
            // You can include version to along with any above condition. 
            document.write("<br /> Browser version info : " + version );  
            //
         --> 
      </script> 
   </body> 
   
</html>

निम्नलिखित आउटपुट उपरोक्त कोड के सफल निष्पादन पर प्रदर्शित होता है।

Mozilla based browser  
Browser version info : 5.0

(Windows NT 6.3; WOW64) AppleWebKit / 537.36 (KHTML, गेको की तरह) क्रोम / 41.0.2272.101 सफारी / 537.36

ES7 - नई सुविधाएँ

यह अध्याय ES7 में नई सुविधाओं के बारे में ज्ञान प्रदान करता है।

घातांक संचालक

ES7 एक नए गणितीय ऑपरेटर का परिचय देता है जिसे एक्सपेक्टोरिएशन ऑपरेटर कहा जाता है। यह ऑपरेटर Math.pow () विधि का उपयोग करने के समान है। घातांक ऑपरेटर को एक डबल तारांकन ** द्वारा दर्शाया गया है। ऑपरेटर का उपयोग केवल संख्यात्मक मानों के साथ किया जा सकता है। प्रतिपादक ऑपरेटर का उपयोग करने का सिंटैक्स नीचे दिया गया है -

वाक्य - विन्यास

प्रतिपादक ऑपरेटर के लिए वाक्य रचना नीचे उल्लिखित है -

base_value ** exponent_value

उदाहरण

निम्नलिखित उदाहरण संख्या का उपयोग कर के घातांक की गणना करता है Math.pow() विधि और exponentiation operator

<script>
   let base = 2
   let exponent = 3
   console.log('using Math.pow()',Math.pow(base,exponent))
   console.log('using exponentiation operator',base**exponent)
</script>

उपरोक्त स्निपेट का आउटपुट नीचे दिया गया है -

using Math.pow() 8
using exponentiation operator 8

ऐरे शामिल हैं

ES7 में शुरू की गई Array.includes () विधि यह जांचने में मदद करती है कि कोई तत्व किसी सरणी में उपलब्ध है या नहीं। ES7 से पहले, सरणी में एक मान मौजूद है, तो यह सत्यापित करने के लिए कि एरे कक्षा का इंडेक्सोफ़ () विधि का उपयोग किया जा सकता है। इंडेक्सऑफ़ () डेटा पाए जाने पर एरे में तत्व की पहली घटना का इंडेक्स लौटाता है, अगर डेटा मौजूद नहीं है, तो रिटर्न -1।

Array.includes () विधि एक पैरामीटर को स्वीकार करती है, जाँचता है कि क्या मान सरणी में मौजूद मान के रूप में दिया गया है। यदि मान मिलता है, तो यह विधि सही है, यदि मान मौजूद नहीं है, तो गलत है। Array.includes () पद्धति का उपयोग करने का सिंटैक्स नीचे दिया गया है -

वाक्य - विन्यास

Array.includes(value)

या

Array.includes(value,start_index)

यदि निर्दिष्ट सूचकांक से मान मौजूद है तो दूसरा सिंटैक्स जांचता है।

उदाहरण

निम्न उदाहरण एक सरणी चिह्न की घोषणा करता है और सरणी में एक मान मौजूद है, यह सत्यापित करने के लिए Array.includes () विधि का उपयोग करता है।

<script>
   let marks = [50,60,70,80]
   //check if 50 is included in array
   if(marks.includes(50)){
      console.log('found element in array')
   }else{
      console.log('could not find element')
   }

   // check if 50 is found from index 1
   if(marks.includes(50,1)){ //search from index 1
      console.log('found element in array')
   }else{
      console.log('could not find element')
   }

   //check Not a Number(NaN) in an array
   console.log([NaN].includes(NaN))

   //create an object array
   let user1 = {name:'kannan'},
   user2 = {name:'varun'},
   user3={name:'prijin'}
   let users = [user1,user2]

   //check object is available in array
   console.log(users.includes(user1))
   console.log(users.includes(user3))
</script>

उपरोक्त कोड का आउटपुट निम्नानुसार होगा -

found element in array
could not find element
true
true
false

ईएस 8 - नई सुविधाएँ

यह अध्याय ईएस 8 में नई सुविधाओं पर केंद्रित है।

पैडिंग एक स्ट्रिंग

ES8 एक स्ट्रिंग पैडिंग के लिए दो स्ट्रिंग हैंडलिंग कार्यों का परिचय देता है। इन फ़ंक्शन का उपयोग स्ट्रिंग मान के आरंभ और अंत में स्थान या किसी भी वांछित वर्ण को जोड़ने के लिए किया जा सकता है।

स्ट्रिंग। padStart ()

यह फ़ंक्शन प्रारंभ से बार-बार दिए गए इनपुट स्ट्रिंग के साथ वर्तमान स्ट्रिंग को पैड करता है, जब तक कि वर्तमान स्ट्रिंग दी गई लंबाई तक नहीं पहुंच जाती। पैडस्टार्ट () फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

वाक्य - विन्यास

string_value.padStart(targetLength [, padString])

पैडस्टार्ट () फ़ंक्शन दो मापदंडों को स्वीकार करता है जो निम्नानुसार हैं -

  • targetLength- एक संख्यात्मक मान जो पैडिंग के बाद स्ट्रिंग की लक्ष्य लंबाई का प्रतिनिधित्व करता है। यदि इस पैरामीटर का मान स्ट्रिंग की मौजूदा लंबाई से कम या उसके बराबर है, तो स्ट्रिंग मान वापस आ जाता है।

  • padString- यह एक वैकल्पिक पैरामीटर है। यह पैरामीटर उन वर्णों को निर्दिष्ट करता है जिनका उपयोग स्ट्रिंग को पैड करने के लिए किया जाना चाहिए। यदि कोई मान इस पैरामीटर के लिए पारित नहीं किया जाता है, तो स्ट्रिंग मान रिक्त स्थान के साथ गद्देदार होता है।

उदाहरण

निम्न उदाहरण एक स्ट्रिंग चर, product_cost की घोषणा करता है। चर बाईं ओर से शून्य से गद्देदार होगा जब तक कि स्ट्रिंग की कुल लंबाई सात नहीं हो जाती। उदाहरण पैडस्टार्ट () फ़ंक्शन के व्यवहार को भी दिखाता है, अगर कोई मान दूसरे पैरामीटर पर नहीं जाता है।

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

यह फ़ंक्शन दी गई इनपुट स्ट्रिंग के साथ वर्तमान स्ट्रिंग को अंत से बार-बार पैड करता है, जब तक कि वर्तमान स्ट्रिंग निर्दिष्ट लंबाई तक नहीं पहुंच जाती।

पैडएंड () फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

वाक्य - विन्यास

string_value.padEnd(targetLength [, padString])

पैडएंड () फ़ंक्शन दो मापदंडों को स्वीकार करता है -

  • targetLength- एक संख्यात्मक मान जो पैडिंग के बाद स्ट्रिंग की लक्ष्य लंबाई का प्रतिनिधित्व करता है। यदि इस पैरामीटर का मान स्ट्रिंग की मौजूदा लंबाई से कम या उसके बराबर है, तो स्ट्रिंग मान वापस आ जाता है।

  • padString- यह एक वैकल्पिक पैरामीटर है। यह पैरामीटर उन वर्णों को निर्दिष्ट करता है जिनका उपयोग स्ट्रिंग को पैड करने के लिए किया जाना चाहिए। यदि कोई मान इस पैरामीटर के लिए पारित नहीं किया जाता है, तो स्ट्रिंग मान रिक्त स्थान के साथ गद्देदार होता है।

उदाहरण

निम्न उदाहरण एक स्ट्रिंग चर, product_cost की घोषणा करता है। चर ठीक से सात है जब तक चर सही से शून्य के साथ गद्देदार किया जाएगा। उदाहरण पैडस्टार्ट () फ़ंक्शन के व्यवहार को भी दिखाता है, अगर कोई मान दूसरे पैरामीटर पर नहीं जाता है।

<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

ट्रेलिंग कॉमस

एक सूची में अंतिम आइटम के बाद एक अल्पविराम अल्पविराम बस एक अल्पविराम है। ट्रेलिंग कॉमा को अंतिम कॉमा के रूप में भी जाना जाता है।

Commas और Array अनुगामी

Array.prototype.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

ट्रेलिंग कॉमा और फ़ंक्शन कॉल

एक समारोह को परिभाषित करने या लागू करने के दौरान, अनुगामी तर्कों को जावास्क्रिप्ट रनटाइम इंजन द्वारा नजरअंदाज कर दिया जाता है। हालाँकि, दो अपवाद हैं -

  • फ़ंक्शन परिभाषाएँ या मंगलाचरण जिसमें केवल एक अल्पविराम होता है, सिंटेक्सएरर में परिणाम होगा। उदाहरण के लिए, निम्नलिखित स्निपेट एक त्रुटि फेंक देगा -

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

ऑब्जेक्ट: प्रविष्टियाँ () और मान ()

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 ES8 में एक बहुत ही महत्वपूर्ण विशेषता है। यह जावास्क्रिप्ट में प्रॉमिस के लिए एक सिंटैक्टिक चीनी है। प्रतीक्षित कीवर्ड का उपयोग वादों के साथ किया जाता है। इस कीवर्ड का उपयोग किसी वादे के निपटारे तक किसी कार्य के निष्पादन को रोकने के लिए किया जा सकता है। प्रतीक्षित कीवर्ड वादा का मूल्य लौटाता है यदि वादा खारिज कर दिया जाता है, तो यह वादा हल हो जाता है। प्रतीक्षित फ़ंक्शन का उपयोग केवल async के रूप में चिह्नित कार्यों के अंदर ही किया जा सकता है। एक फ़ंक्शन जिसे async कीवर्ड का उपयोग करके घोषित किया जाता है, हमेशा एक वादा वापस करता है।

वाक्य - विन्यास

प्रतीक्षा के साथ async फ़ंक्शन का सिंटैक्स नीचे दिया गया है -

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

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

एक ऐसे उदाहरण पर विचार करें जिसमें एक एसिंक्रोनस फ़ंक्शन होता है जो स्ट्रिंग मान को निष्पादित करने और वापस करने में दो सेकंड लेता है। फ़ंक्शन को दो तरीकों से लागू किया जा सकता है जैसा कि नीचे दिखाया गया है

  • वादे का उपयोग करना। ()
  • Aync / प्रतीक्षा का उपयोग करना।

नीचे दिया गया कोड पारंपरिक ES6 सिंटैक्स - वादे.थेन () का उपयोग करके अतुल्यकालिक फ़ंक्शन को लागू करता है।

<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 / प्रतीक्षा का उपयोग करके अतुल्यकालिक फ़ंक्शन को लागू करने का एक क्लीनर तरीका दिखाया गया है

<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 / प्रतीक्षा के साथ वादा करने का वादा

निम्नलिखित उदाहरण लागू होता है async / प्रतीक्षा सिंटैक्स का उपयोग करते हुए वादा करता हूँ।

इस उदाहरण में, 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

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