ब्राउज़र एक्सटेंशन प्रोजेक्ट भाग 2: एक API कॉल करें, लोकल स्टोरेज का उपयोग करें

January 29, 2026 · View on GitHub

journey
    title आपका API एकीकरण और संग्रहण यात्रा
    section आधार
      DOM संदर्भ सेटअप करें: 3: Student
      घटना श्रोता जोड़ें: 4: Student
      फॉर्म सबमिशन संभालें: 4: Student
    section डेटा प्रबंधन
      स्थानीय संग्रह कार्यान्वित करें: 4: Student
      API कॉल बनाएं: 5: Student
      असिंक्रोनस संचालन संभालें: 5: Student
    section उपयोगकर्ता अनुभव
      त्रुटि हैंडलिंग जोड़ें: 5: Student
      लोडिंग स्टेट्स बनाएं: 4: Student
      इंटरैक्शन को पॉलिश करें: 5: Student

प्री-लेक्चर क्विज़

प्री-लेक्चर क्विज़

परिचय

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

सोचें अपोलो मिशन कंट्रोल कम्प्यूटर्स के बारे में - वे सिर्फ स्थिर जानकारी प्रदर्शित नहीं करते थे। वे लगातार अंतरिक्ष यान से संवाद करते थे, टेलीमेट्री डेटा के साथ अपडेट होते थे, और महत्वपूर्ण मिशन पैरामीटर्स को याद रखते थे। आज हम ऐसी ही गतिशील व्यवहार बना रहे हैं। आपका एक्सटेंशन इंटरनेट से वास्तविक पर्यावरणीय डेटा प्राप्त करेगा, और आपकी सेटिंग्स को अगली बार के लिए याद रखेगा।

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

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

mindmap
  root((Dynamic Extensions))
    DOM Manipulation
      Element Selection
      Event Handling
      State Management
      UI Updates
    Local Storage
      Data Persistence
      Key-Value Pairs
      Session Management
      User Preferences
    API Integration
      HTTP Requests
      Authentication
      Data Parsing
      Error Handling
    Async Programming
      Promises
      Async/Await
      Error Catching
      Non-blocking Code
    User Experience
      Loading States
      Error Messages
      Smooth Transitions
      Data Validation

✅ उचित फ़ाइलों में क्रमांकित हिस्सों का पालन करें ताकि पता चले कि कोड कहाँ रखना है

एक्सटेंशन में नियंत्रण करने के लिए तत्व सेट करें

आपके जावास्क्रिप्ट को इंटरफेस में बदलाव करने से पहले, इसे विशेष HTML तत्वों के संदर्भ चाहिए। इसे ऐसे समझें जैसे टेलीस्कोप को विशिष्ट तारों की तरफ मोड़ना - गैलीलियो ने बृहस्पति के चंद्रमाओं का अध्ययन करने से पहले बृहस्पति को ढूंढकर फोकस करना पड़ा था।

आपकी index.js फाइल में, हम const वेरिएबल बनाएंगे जो प्रत्येक महत्वपूर्ण फॉर्म तत्व के संदर्भों को कैप्चर करेंगे। यह वैसे ही है जैसे वैज्ञानिक अपने उपकरणों को लेबल करते हैं - हर बार पूरे प्रयोगशाला में खोजने के बजाय, वे सीधे उस तक पहुँच सकते हैं जिसकी उन्हें जरूरत है।

flowchart LR
    A[JavaScript कोड] --> B[document.querySelector]
    B --> C[CSS चयनकर्ता]
    C --> D[HTML तत्व]
    
    D --> E[".form-data"]
    D --> F[".region-name"]
    D --> G[".api-key"]
    D --> H[".loading"]
    D --> I[".errors"]
    D --> J[".result-container"]
    
    E --> K[फॉर्म तत्व]
    F --> L[इनपुट क्षेत्र]
    G --> M[इनपुट क्षेत्र]
    H --> N[UI तत्व]
    I --> O[UI तत्व]
    J --> P[UI तत्व]
    
    style A fill:#e1f5fe
    style D fill:#e8f5e8
    style K fill:#fff3e0
    style L fill:#fff3e0
    style M fill:#fff3e0
// फ़ॉर्म फ़ील्ड्स
const form = document.querySelector('.form-data');
const region = document.querySelector('.region-name');
const apiKey = document.querySelector('.api-key');

// परिणाम
const errors = document.querySelector('.errors');
const loading = document.querySelector('.loading');
const results = document.querySelector('.result-container');
const usage = document.querySelector('.carbon-usage');
const fossilfuel = document.querySelector('.fossil-fuel');
const myregion = document.querySelector('.my-region');
const clearBtn = document.querySelector('.clear-btn');

यह कोड क्या करता है:

  • कैप्चर करता है document.querySelector() के साथ CSS क्लास सेलेक्टर्स उपयोग करके फॉर्म तत्वों को
  • निर्माण करता है क्षेत्र नाम और API कुंजी के इनपुट फ़ील्ड्स के संदर्भ
  • स्थापित करता है परिणाम प्रदर्शन तत्वों को कार्बन उपयोग डेटा के लिए
  • सेटअप करता है लोडिंग इंडिकेटर और त्रुटि संदेश जैसे UI तत्वों तक पहुँच
  • संग्रहित करता है प्रत्येक तत्व का संदर्भ एक const वेरिएबल में ताकि पूरे कोड में आसानी से पुनः उपयोग किया जा सके

इवेंट लिसनर्स जोड़ें

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

sequenceDiagram
    participant User
    participant Form
    participant JavaScript
    participant API
    participant Storage
    
    User->>Form: क्षेत्र/API कुंजी भरता है
    User->>Form: सबमिट पर क्लिक करता है
    Form->>JavaScript: सबमिट इवेंट ट्रिगर करता है
    JavaScript->>JavaScript: handleSubmit(e)
    JavaScript->>Storage: उपयोगकर्ता प्राथमिकताएँ सहेजें
    JavaScript->>API: कार्बन डेटा प्राप्त करें
    API->>JavaScript: डेटा लौटाता है
    JavaScript->>Form: परिणामों के साथ UI अपडेट करें
    
    User->>Form: क्लियर बटन पर क्लिक करता है
    Form->>JavaScript: क्लिक इवेंट ट्रिगर करता है
    JavaScript->>Storage: सहेजा हुआ डेटा साफ़ करें
    JavaScript->>Form: प्रारंभिक स्थिति पर रीसेट करें
form.addEventListener('submit', (e) => handleSubmit(e));
clearBtn.addEventListener('click', (e) => reset(e));
init();

इन अवधारणाओं को समझना:

  • अटैच करता है सबमिट लिसनर को फ़ॉर्म से जो तब ट्रिगर होता है जब उपयोगकर्ता Enter दबाते हैं या सबमिट करते हैं
  • कनेक्ट करता है क्लिक लिसनर को क्लियर बटन से फॉर्म रीसेट के लिए
  • इवेंट ऑब्जेक्ट (e) पास करता है हैंडलर फंक्शंस को अतिरिक्त नियंत्रण के लिए
  • init() फ़ंक्शन को तुरंत कॉल करता है एक्सटेंशन की प्रारंभिक स्थिति सेट करने के लिए

✅ ध्यान दें कि यहाँ संक्षिप्त एरो फंक्शन सिंटैक्स उपयोग हुआ है। यह आधुनिक जावास्क्रिप्ट तरीका पारंपरिक फंक्शन एक्सप्रेशन्स से अधिक साफ-सुथरा है, लेकिन दोनों काम करते हैं!

🔄 शैक्षिक जांच

इवेंट हैंडलिंग समझ: इनिशियलाइजेशन से पहले सुनिश्चित करें कि आप:

  • ✅ बता सकते हैं कि addEventListener उपयोगकर्ता क्रियाओं को जावास्क्रिप्ट फंक्शंस से कैसे जोड़ता है
  • ✅ समझते हैं कि हम इवेंट ऑब्जेक्ट (e) हैंडलर फंक्शंस को क्यों पास करते हैं
  • ✅ पहचान सकते हैं submit और click इवेंट में क्या अंतर है
  • ✅ बता सकते हैं init() फ़ंक्शन कब चलता है और क्यों

त्वरित आत्म-परीक्षा: यदि आपने फ़ॉर्म सबमिशन में e.preventDefault() भूल गए तो क्या होगा? उत्तर: पेज रीलोड होगा, सभी जावास्क्रिप्ट स्टेट खो जाएगी और उपयोगकर्ता अनुभव बाधित होगा

इनिशियलाइज़ेशन और रीसेट फंक्शंस बनाएं

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

reset() फ़ंक्शन उपयोगकर्ताओं को नया आरंभ प्रदान करता है - जैसे वैज्ञानिक अपने उपकरणों को प्रयोगों के बीच रीसेट करते हैं ताकि साफ डेटा सुनिश्चित किया जा सके।

function init() {
	// जांचें कि उपयोगकर्ता ने पहले से API प्रमाण पत्र सहेजे हैं या नहीं
	const storedApiKey = localStorage.getItem('apiKey');
	const storedRegion = localStorage.getItem('regionName');

	// एक्सटेंशन आइकन को सामान्य हरे रंग में सेट करें (भविष्य के पाठ के लिए प्लेसहोल्डर)
	// TODO: अगले पाठ में आइकन अपडेट को लागू करें

	if (storedApiKey === null || storedRegion === null) {
		// पहली बार उपयोगकर्ता: सेटअप फॉर्म दिखाएं
		form.style.display = 'block';
		results.style.display = 'none';
		loading.style.display = 'none';
		clearBtn.style.display = 'none';
		errors.textContent = '';
	} else {
		// लौटने वाला उपयोगकर्ता: उनके सहेजे गए डेटा को स्वचालित रूप से लोड करें
		displayCarbonUsage(storedApiKey, storedRegion);
		results.style.display = 'none';
		form.style.display = 'none';
		clearBtn.style.display = 'block';
	}
}

function reset(e) {
	e.preventDefault();
	// संग्रहीत क्षेत्र को साफ करें ताकि उपयोगकर्ता नया स्थान चुन सके
	localStorage.removeItem('regionName');
	// प्रारंभिक प्रक्रिया को पुनः शुरू करें
	init();
}

यहाँ क्या हो रहा है:

  • प्राप्त करता है संग्रहीत API कुंजी और क्षेत्र को ब्राउज़र के लोकल स्टोरेज से
  • जाँचता है कि यह प्रथम बार उपयोगकर्ता है (कोई संग्रहित क्रेडेंशियल्स नहीं) या पुनः आने वाला उपयोगकर्ता
  • दिखाता है नए उपयोगकर्ताओं के लिए सेटअप फॉर्म और छुपाता है अन्य इंटरफेस तत्व
  • स्वचालित रूप से लोड करता है वापस आने वाले उपयोगकर्ताओं के लिए सहेजा गया डेटा और दिखाता है रीसेट विकल्प
  • प्रबंधित करता है उपयोगकर्ता इंटरफेस की स्थिति उपलब्ध डेटा के आधार पर

लोकल स्टोरेज के बारे में महत्वपूर्ण बातें:

  • स्थायी करता है ब्राउज़र सत्रों के बीच डेटा (सेशन स्टोरेज के विपरीत)
  • संग्रहित करता है डेटा को कुंजी-मूल्य जोड़े के रूप में getItem() और setItem() का उपयोग कर
  • null लौटाता है जब किसी कुंजी के लिए डेटा मौजूद नहीं होता
  • सरल तरीका प्रदान करता है उपयोगकर्ता प्राथमिकताओं और सेटिंग्स को याद रखने के लिए

💡 ब्राउज़र स्टोरेज समझना: LocalStorage आपके एक्सटेंशन को दी गई स्थायी मेमोरी है। कल्पना करें कैसे प्राचीन अलेक्जेंड्रिया की लाइब्रेरी स्क्रॉल्स संग्रहीत करती थी - जानकारी तब भी उपलब्ध रहती थी जब विद्वान चले जाते और वापस लौटते थे।

मुख्य विशेषताएँ:

  • स्थायी रहती है भले ही आप ब्राउज़र बंद कर दें
  • कंप्यूटर रीस्टार्ट और ब्राउज़र क्रैश से सुरक्षित
  • उपयोगकर्ता प्राथमिकताओं के लिए पर्याप्त संग्रहण स्थान
  • नेटवर्क विलंब के बिना त्वरित पहुँच उपलब्ध

महत्वपूर्ण नोट: आपका ब्राउज़र एक्सटेंशन अपनी अलग-थलग लोकल स्टोरेज रखता है जो नियमित वेब पेजेस से अलग है। यह सुरक्षा प्रदान करता है और अन्य वेबसाइटों से टकराव को रोकता है।

आप डेवलपर टूल्स (F12) खोलकर, Application टैब पर जाकर, और Local Storage सेक्शन विस्तारित करके अपना संग्रहित डेटा देख सकते हैं।

stateDiagram-v2
    [*] --> CheckStorage: एक्सटेंशन शुरू होता है
    CheckStorage --> FirstTime: कोई संग्रहीत डेटा नहीं
    CheckStorage --> Returning: डेटा मिला
    
    FirstTime --> ShowForm: सेटअप फॉर्म दिखाएँ
    ShowForm --> UserInput: उपयोगकर्ता डेटा दर्ज करता है
    UserInput --> SaveData: localStorage में सहेजें
    SaveData --> FetchAPI: कार्बन डेटा प्राप्त करें
    
    Returning --> LoadData: localStorage से पढ़ें
    LoadData --> FetchAPI: कार्बन डेटा प्राप्त करें
    
    FetchAPI --> ShowResults: डेटा दिखाएँ
    ShowResults --> UserAction: उपयोगकर्ता इंटरैक्ट करता है
    
    UserAction --> Reset: क्लियर बटन क्लिक किया गया
    UserAction --> ShowResults: डेटा देखें
    
    Reset --> ClearStorage: सहेजा गया डेटा हटाएँ
    ClearStorage --> FirstTime: सेटअप पर वापस जाएं

Local storage pane

⚠️ सुरक्षा विचार: प्रोडक्शन एप्लिकेशन में API कुंजी लोकलस्टोरेज में रखना सुरक्षा जोखिम पैदा करता है क्योंकि जावास्क्रिप्ट इस डेटा तक पहुँच सकता है। सीखने के लिए यह ठीक है, लेकिन असली एप्लिकेशन संवेदनशील क्रेडेंशियल्स के लिए सुरक्षित सर्वर-साइड स्टोरेज का उपयोग करना चाहिए।

फॉर्म सबमिशन हैंडल करें

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

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

एक फ़ंक्शन बनाएं जो फॉर्म सबमिशन इवेंट को पकड़ता है और उपयोगकर्ता इनपुट निकालता है:

function handleSubmit(e) {
	e.preventDefault();
	setUpUser(apiKey.value, region.value);
}

ऊपर हमने:

  • रोक दिया डिफ़ॉल्ट फॉर्म सबमिशन व्यवहार जो पेज रीलोड करता
  • निकाला API कुंजी और क्षेत्र फ़ील्ड से उपयोगकर्ता इनपुट मान
  • पास किया फॉर्म डेटा को setUpUser() फ़ंक्शन के लिए प्रोसेसिंग हेतु
  • सुनिश्चित किया सिंगल-पेज एप्लिकेशन व्यवहार बिना पेज रीलोड के

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

उपयोगकर्ता प्राथमिकताएँ सेट करें

setUpUser फ़ंक्शन उपयोगकर्ता के क्रेडेंशियल्स को सहेजने और पहली API कॉल शुरू करने के लिए जिम्मेदार है। यह सेटअप से परिणाम दिखाने तक के लिए एक सहज संक्रमण बनाता है।

function setUpUser(apiKey, regionName) {
	// भविष्य के सत्रों के लिए उपयोगकर्ता प्रमाण-पत्र सहेजें
	localStorage.setItem('apiKey', apiKey);
	localStorage.setItem('regionName', regionName);
	
	// लोडिंग स्थिति दिखाने के लिए UI अपडेट करें
	loading.style.display = 'block';
	errors.textContent = '';
	clearBtn.style.display = 'block';
	
	// उपयोगकर्ता के प्रमाण-पत्र के साथ कार्बन उपयोग डेटा प्राप्त करें
	displayCarbonUsage(apiKey, regionName);
}

क्रमवार, यह हो रहा है:

  • सहेजता है API कुंजी और क्षेत्र नाम लोकल स्टोरेज में भविष्य के उपयोग के लिए
  • दिखाता है लोडिंग इंडिकेटर ताकि उपयोगकर्ता को पता चले डेटा लोड हो रहा है
  • मिटाता है पुराने किसी भी त्रुटि संदेश को प्रदर्शन से
  • प्रकट करता है क्लियर बटन ताकि उपयोगकर्ता बाद में अपनी सेटिंग्स रीसेट कर सकें
  • शुरू करता है API कॉल जो वास्तविक कार्बन उपयोग डेटा लाता है

यह फ़ंक्शन डेटा स्थिरता और UI अपडेट को एक समन्वित क्रिया में प्रबंधित करके निरंतर उपयोगकर्ता अनुभव बनाता है।

कार्बन उपयोग डेटा प्रदर्शित करें

अब हम आपके एक्सटेंशन को बाहरी डेटा स्रोतों से API के माध्यम से जोड़ेंगे। इसका अर्थ है आपका एक्सटेंशन एक स्टैंडअलोन टूल से बदलकर इंटरनेट से वास्तविक समय की जानकारी प्राप्त करने वाला होगा।

API समझना

APIs अलग-अलग एप्लिकेशन कैसे एक दूसरे से संवाद करते हैं, इसका तरीका हैं। इन्हें ऐसे समझें जैसे 19वीं सदी के टेलीग्राफ सिस्टम जो दूर-दराज़ शहरों को जोड़ता था - ऑपरेटर दूर स्टेशन को अनुरोध भेजते और जवाब प्राप्त करते थे। जब भी आप सोशल मीडिया देखते हैं, वॉयस असिस्टेंट को प्रश्न पूछते हैं, या डिलीवरी एप का उपयोग करते हैं, API ऐसे डेटा एक्सचेंजों की सुविधा देता है।

flowchart TD
    A[आपका एक्सटेंशन] --> B[HTTP अनुरोध]
    B --> C[CO2 सिग्नल API]
    C --> D{वैध अनुरोध?}
    D -->|हाँ| E[डेटाबेस क्वेरी करें]
    D -->|नहीं| F[त्रुटि लौटाएं]
    E --> G[कार्बन डेटा]
    G --> H[JSON उत्तर]
    H --> I[आपका एक्सटेंशन]
    F --> I
    I --> J[यूआई अपडेट करें]
    
    subgraph "API अनुरोध"
        K[हेडर: auth-token]
        L[पैरामीटर: countryCode]
        M[मेथड: GET]
    end
    
    subgraph "API प्रतिक्रिया"
        N[कार्बन तीव्रता]
        O[फॉसिल ईंधन %]
        P[टाइमस्टैम्प]
    end
    
    style C fill:#e8f5e8
    style G fill:#fff3e0
    style I fill:#e1f5fe

REST API के बारे में मुख्य बातें:

  • REST का अर्थ है 'Representational State Transfer'
  • उपयोग करता है मानक HTTP विधियाँ (GET, POST, PUT, DELETE) डेटा के साथ इंटरैक्शन के लिए
  • डेटा लौटाता है अनुमानित स्वरूपों में, आमतौर पर JSON में
  • प्रदान करता है एकसमान, URL-आधारित एंडपॉइंट्स विभिन्न अनुरोध प्रकारों के लिए

CO2 Signal API जो हम उपयोग करेंगे विश्वव्यापी विद्युत ग्रिड से वास्तविक समय का कार्बन तीव्रता डेटा प्रदान करता है। यह उपयोगकर्ताओं को उनके बिजली उपयोग के पर्यावरणीय प्रभाव को समझने में मदद करता है!

💡 असिंक्रोनस जावास्क्रिप्ट समझना: async कीवर्ड आपके कोड को कई ऑपरेशंस को एक साथ संभालने में सक्षम बनाता है। जब आप सर्वर से डेटा मांगते हैं, तो आप नहीं चाहते कि आपका पूरा एक्सटेंशन फ्रीज़ हो जाए - यह ऐसे होगा जैसे एयर ट्रैफिक कंट्रोल एक विमान के जवाब तक सभी ऑपरेशन रोक दे।

मुख्य लाभ:

  • एक्सटेंशन की प्रतिक्रियाशीलता बनाए रखता है जब डेटा लोड हो रहा हो
  • अन्य कोड को जारी रखने देता है नेटवर्क अनुरोध के दौरान भी
  • पारंपरिक कॉलबैक पैटर्न की तुलना में अधिक पठनीय कोड
  • नेटवर्क समस्याओं के लिए बेहतर त्रुटि प्रबंधन सक्षम करता है

यहाँ एक त्वरित वीडियो है async के बारे में:

Async और Await के प्रबंधन के लिए promises

🎥 ऊपर चित्र पर क्लिक करें async/await के बारे में वीडियो देखने के लिए।

🔄 शैक्षिक जांच

Async प्रोग्रामिंग समझना: API फ़ंक्शन में उतरने से पहले यह सुनिश्चित करें कि आप समझते हैं:

  • ✅ हम पूरी एक्सटेंशन को ब्लॉक किए बिना async/await क्यों उपयोग करते हैं
  • try/catch ब्लॉक नेटवर्क त्रुटियों को कैसे संभालते हैं
  • ✅ सिंक्रोनस और असिंक्रोनस कार्यों में क्या अंतर है
  • ✅ API कॉल क्यों असफल हो सकते हैं और उन असफलताओं को कैसे संभालें

वास्तविक दुनिया के उदाहरण: ये रोजमर्रा के असिंक्रोनस उदाहरण सोचें:

  • खाना ऑर्डर करना: आप किचन के पास इंतजार नहीं करते - रसीद लेते हैं और अन्य काम करते रहते हैं
  • ईमेल भेजना: आपका ईमेल ऐप सेंडिंग के दौरान फ्रीज़ नहीं होता - आप और ईमेल बना सकते हैं
  • वेब पेज लोडिंग: इमेजेज़ क्रमिक रूप से लोड होती हैं जबकि आप पहले से टेक्स्ट पढ़ सकते हैं

API प्रमाणीकरण फ्लो:

sequenceDiagram
    participant Ext as एक्सटेंशन
    participant API as CO2 सिग्नल API
    participant DB as डेटाबेस
    
    Ext->>API: प्रमाणीकरण टोकन के साथ अनुरोध
    API->>API: टोकन सत्यापित करें
    API->>DB: कार्बन डेटा पूछताछ
    DB->>API: डेटा लौटाएं
    API->>Ext: JSON प्रतिक्रिया
    Ext->>Ext: UI अपडेट करें

कार्बन उपयोग डेटा लाने और प्रदर्शित करने का फ़ंक्शन बनाएं:

// आधुनिक fetch API दृष्टिकोण (कोई बाहरी निर्भरता आवश्यक नहीं)
async function displayCarbonUsage(apiKey, region) {
	try {
		// CO2 सिग्नल API से कार्बन तीव्रता डेटा प्राप्त करें
		const response = await fetch('https://api.co2signal.com/v1/latest', {
			method: 'GET',
			headers: {
				'auth-token': apiKey,
				'Content-Type': 'application/json'
			},
			// विशिष्ट क्षेत्र के लिए क्वेरी पैरामीटर जोड़ें
			...new URLSearchParams({ countryCode: region }) && {
				url: `https://api.co2signal.com/v1/latest?countryCode=${region}`
			}
		});

		// जांचें कि API अनुरोध सफल था या नहीं
		if (!response.ok) {
			throw new Error(`API request failed: ${response.status}`);
		}

		const data = await response.json();
		const carbonData = data.data;

		// गोलाकार कार्बन तीव्रता मान की गणना करें
		const carbonIntensity = Math.round(carbonData.carbonIntensity);

		// प्राप्त डेटा के साथ उपयोगकर्ता इंटरफ़ेस अपडेट करें
		loading.style.display = 'none';
		form.style.display = 'none';
		myregion.textContent = region.toUpperCase();
		usage.textContent = `${carbonIntensity} grams (grams CO₂ emitted per kilowatt hour)`;
		fossilfuel.textContent = `${carbonData.fossilFuelPercentage.toFixed(2)}% (percentage of fossil fuels used to generate electricity)`;
		results.style.display = 'block';

		// TODO: calculateColor(carbonIntensity) - अगले पाठ में लागू करें

	} catch (error) {
		console.error('Error fetching carbon data:', error);
		
		// उपयोगकर्ता के अनुकूल त्रुटि संदेश दिखाएं
		loading.style.display = 'none';
		results.style.display = 'none';
		errors.textContent = 'Sorry, we couldn\'t fetch data for that region. Please check your API key and region code.';
	}
}

यहाँ क्या हो रहा है:

  • आधुनिक fetch() API उपयोग करता है बाहरी लाइब्रेरी जैसे Axios के बजाय, ताकि कोड साफ और बिना निर्भरता का रहे
  • सही त्रुटि जांच करता है response.ok के साथ ताकि API विफलताएँ जल्दी पकड़ ली जाएं
  • async/await का उपयोग करके असिंक्रोनस ऑपरेशंस संभालता है जिससे कोड प्रवाह पढ़ने में आसान हो
  • CO2 Signal API के साथ auth-token हेडर का उपयोग कर प्रमाणीकरण करता है
  • JSON प्रतिक्रिया को पार्स करता है और कार्बन तीव्रता जानकारी निकालता है
  • कैसे कई UI तत्व अपडेट करता है पर्यावरणीय डेटा के साथ फॉर्मेट करके
  • API कॉल विफल होने पर उपयोगकर्ता के अनुकूल त्रुटि संदेश प्रदर्शित करता है

आधुनिक जावास्क्रिप्ट अवधारणाएँ प्रदर्शित करता है:

  • ${} सिंटैक्स के साथ टेम्प्लेट लिटरेल्स साफ स्ट्रिंग फॉर्मेटिंग के लिए
  • try/catch ब्लॉक्स के साथ त्रुटि प्रबंधन मजबूत एप्लिकेशन के लिए
  • async/await पैटर्न नेटवर्क अनुरोधों को सहजता से संभालने के लिए
  • ऑब्जेक्ट डेस्ट्रक्चरिंग API प्रतिक्रियाओं से विशिष्ट डेटा निकालने के लिए
  • मेथड चेनिंग एक से अधिक DOM मैनिपुलेशन के लिए

✅ यह फ़ंक्शन कई महत्वपूर्ण वेब विकास अवधारणाओं को दर्शाता है - बाहरी सर्वरों से संवाद, प्रमाणीकरण, डेटा प्रोसेसिंग, इंटरफेस अपडेट, और त्रुटि प्रबंधन। ये वे मूल कौशल हैं जो पेशेवर डेवलपर्स नियमित रूप से उपयोग करते हैं।

flowchart TD
    A[एपीआई कॉल शुरू करें] --> B[अनुरोध प्राप्त करें]
    B --> C{नेटवर्क सफल?}
    C -->|नहीं| D[नेटवर्क त्रुटि]
    C -->|हाँ| E{प्रतिक्रिया ठीक है?}
    E -->|नहीं| F[एपीआई त्रुटि]
    E -->|हाँ| G[JSON पार्स करें]
    G --> H{डेटा मान्य है?}
    H -->|नहीं| I[डेटा त्रुटि]
    H -->|हाँ| J[यूआई अपडेट करें]
    
    D --> K[त्रुटि संदेश दिखाएं]
    F --> K
    I --> K
    J --> L[लोडिंग छुपाएं]
    K --> L
    
    style A fill:#e1f5fe
    style J fill:#e8f5e8
    style K fill:#ffebee
    style L fill:#f3e5f5

🔄 शैक्षिक जांच

पूरा सिस्टम समझना: पूरे फ्लो में आपकी महारत का सत्यापन करें:

  • ✅ कैसे DOM संदर्भ जावास्क्रिप्ट को इंटरफेस नियंत्रित करने देते हैं
  • ✅ क्यों लोकल स्टोरेज ब्राउज़र सत्रों के बीच स्थिरता बनाता है
  • ✅ कैसे async/await API कॉल्स को एक्सटेंशन को फ्रीज़ किए बिना बनाता है
  • ✅ API कॉल विफल होने पर क्या होता है और त्रुटियाँ कैसे संभाली जाती हैं
  • ✅ क्यों उपयोगकर्ता अनुभव में लोडिंग स्थिति और त्रुटि संदेश शामिल होते हैं

🎉 आपने जो हासिल किया है: आपने एक ब्राउज़र एक्सटेंशन बनाया है जो:

  • इंटरनेट से जुड़ता है और वास्तविक पर्यावरणीय डेटा प्राप्त करता है
  • उपयोगकर्ता सेटिंग्स को स्थायी करता है सत्रों के बीच
  • त्रुटियों को सहजता से संभालता है बिना क्रैश किए
  • एक Smooth, प्रोफेशनल उपयोगकर्ता अनुभव प्रदान करता है

अपना कार्य npm run build चलाकर और अपने एक्सटेंशन को ब्राउज़र में रिफ्रेश करके टेस्ट करें। अब आपके पास एक कार्यशील कार्बन फुटप्रिंट ट्रैकर है। अगला पाठ एक्सटेंशन को पूरा करने के लिए डायनामिक आइकन कार्यक्षमता जोड़ेगा।


GitHub Copilot Agent Challenge 🚀

निम्नलिखित चुनौती पूरी करने के लिए Agent मोड का उपयोग करें: विवरण: ब्राउज़र एक्सटेंशन को त्रुटि हैंडलिंग सुधारों और उपयोगकर्ता अनुभव सुविधाओं को जोड़कर बेहतर बनाएं। यह चुनौती आपको आधुनिक जावास्क्रिप्ट पैटर्न का उपयोग करके API के साथ काम करने, लोकल स्टोरेज, और DOM मैनिपुलेशन का अभ्यास करने में मदद करेगी।

प्रॉम्प्ट: displayCarbonUsage फ़ंक्शन का एक संवर्धित संस्करण बनाएं जिसमें शामिल हो: 1) असफल API कॉल के लिए एक्सपोनेंशियल बैकऑफ के साथ रीट्राई मैकेनिज्म, 2) API कॉल करने से पहले रीजन कोड के लिए इनपुट वैलिडेशन, 3) प्रगति संकेतकों के साथ लोडिंग एनीमेशन, 4) API प्रतिक्रियाओं को localStorage में कैश करना और समाप्ति टाइमस्टैम्प (30 मिनट के लिए कैश करें), और 5) पहले किए गए API कॉल से ऐतिहासिक डेटा प्रदर्शित करने की सुविधा। साथ ही सभी फ़ंक्शन पैरामीटर्स और रिटर्न टाइप्स का डॉक्यूमेंटेशन करने के लिए उपयुक्त TypeScript-शैली के JSDoc टिप्पणियाँ जोड़ें।

agent mode के बारे में और जानें।

🚀 चुनौती

API की अपनी समझ का विस्तार करें और वेब विकास के लिए उपलब्ध ब्राउज़र-आधारित API की संपदा का अन्वेषण करें। इनमें से किसी एक ब्राउज़र API को चुनें और एक छोटा डेमो बनाएं:

  • Geolocation API - उपयोगकर्ता का वर्तमान स्थान प्राप्त करें
  • Notification API - डेस्कटॉप सूचनाएँ भेजें
  • HTML Drag and Drop API - इंटरैक्टिव ड्रैग इंटरफेस बनाएं
  • Web Storage API - उन्नत लोकल स्टोरेज तकनीकें
  • Fetch API - XMLHttpRequest का आधुनिक विकल्प

संदर्भ प्रश्न विचार करने के लिए:

  • यह API वास्तविक दुनिया की कौन सी समस्याओं को हल करता है?
  • यह API त्रुटियों और एज केसों को कैसे संभालता है?
  • इस API का उपयोग करते समय कौन से सुरक्षा विचार होते हैं?
  • यह API विभिन्न ब्राउज़रों में कितना व्यापक रूप से समर्थित है?

अपने शोध के बाद, पहचानें कि कौन से गुण एक API को डेवलपर-अनुकूल और विश्वसनीय बनाते हैं।

लेक्चर के बाद का क्विज़

Post-lecture quiz

समीक्षा और स्व-अध्ययन

आपने इस पाठ में LocalStorage और API के बारे में सीखा, जो दोनों पेशेवर वेब डेवलपर के लिए बहुत उपयोगी हैं। क्या आप सोच सकते हैं कि ये दोनों चीजें कैसे साथ काम करती हैं? सोचें कि आप एक वेबसाइट का वास्तुकला कैसे बनाएंगे जो API द्वारा उपयोग किए जाने वाले आइटम स्टोर करेगा।

अगले 5 मिनट में आप क्या कर सकते हैं

  • DevTools के Application टैब को खोलें और किसी भी वेबसाइट पर localStorage का अन्वेषण करें
  • एक सरल HTML फॉर्म बनाएं और ब्राउज़र में फॉर्म वैलिडेशन का परीक्षण करें
  • ब्राउज़र कंसोल में localStorage का उपयोग करके डेटा संग्रहित और पुनः प्राप्त करने का प्रयास करें
  • नेटवर्क टैब का उपयोग करके सबमिट किए जा रहे फॉर्म डेटा का निरीक्षण करें

🎯 इस घंटे में आप क्या हासिल कर सकते हैं

  • पोस्ट-लेसन क्विज़ पूरा करें और फॉर्म हैंडलिंग अवधारणाओं को समझें
  • एक ब्राउज़र एक्सटेंशन फॉर्म बनाएं जो उपयोगकर्ता की प्राथमिकताओं को सहेजता है
  • सहायक त्रुटि संदेशों के साथ क्लाइंट-साइड फॉर्म वैलिडेशन लागू करें
  • एक्सटेंशन डेटा स्थिरता के लिए chrome.storage API का अभ्यास करें
  • एक उपयोगकर्ता इंटरफ़ेस बनाएँ जो सहेजे गए उपयोगकर्ता सेटिंग्स के अनुसार प्रतिक्रिया देता है

📅 आपका सप्ताह भर का एक्सटेंशन निर्माण

  • फॉर्म कार्यक्षमता के साथ एक पूर्ण विशेषताओं वाला ब्राउज़र एक्सटेंशन पूरा करें
  • विभिन्न संग्रह विकल्पों में महारत हासिल करें: स्थानीय, सिंक, और सेशन स्टोरेज
  • ऑटोकम्प्लीट और वैलिडेशन जैसी उन्नत फॉर्म विशेषताएं लागू करें
  • उपयोगकर्ता डेटा के लिए आयात/निर्यात कार्यक्षमता जोड़ें
  • विभिन्न ब्राउज़रों में अपने एक्सटेंशन का अच्छी तरह परीक्षण करें
  • अपने एक्सटेंशन के उपयोगकर्ता अनुभव और त्रुटि हैंडलिंग को परिष्कृत करें

🌟 आपका महीने भर का वेब API मास्टरी

  • विभिन्न ब्राउज़र स्टोरेज API का उपयोग करके जटिल अनुप्रयोग बनाएं
  • ऑफ़लाइन-प्रथम विकास पैटर्न के बारे में जानें
  • डेटा स्थिरता से जुड़ी ओपन सोर्स परियोजनाओं में योगदान दें
  • गोपनीयता-केंद्रित विकास और GDPR अनुपालन में महारत हासिल करें
  • फॉर्म हैंडलिंग और डेटा प्रबंधन के लिए पुन: उपयोग करने योग्य पुस्तकालय बनाएं
  • वेब API और एक्सटेंशन विकास के बारे में ज्ञान साझा करें

🎯 आपका एक्सटेंशन विकास मास्टरी टाइमलाइन

timeline
    title API एकीकरण और स्टोरेज सीखने की प्रगति
    
    section DOM मूल बातें (15 मिनट)
        तत्व संदर्भ: querySelector महारत
                      : इवेंट लिसनर सेटअप
                      : स्टेट प्रबंधन के मूल सिद्धांत
        
    section लोकल स्टोरेज (20 मिनट)
        डेटा स्थिरता: कुंजी-मूल्य भंडारण
                    : सेशन प्रबंधन
                    : उपयोगकर्ता प्राथमिकता हैंडलिंग
                    : स्टोरेज निरीक्षण उपकरण
        
    section फॉर्म हैंडलिंग (25 मिनट)
        उपयोगकर्ता इनपुट: फॉर्म मान्यता
                     : इवेंट रोकथाम
                     : डेटा निष्कर्षण
                     : UI स्थिति संक्रमण
        
    section API एकीकरण (35 मिनट)
        बाहरी संचार: HTTP अनुरोध
                   : प्रमाणीकरण पैटर्न
                   : JSON डेटा पार्सिंग
                   : प्रतिक्रिया हैंडलिंग
        
    section एसिंक प्रोग्रामिंग (40 मिनट)
        आधुनिक जावास्क्रिप्ट: प्रॉमिस हैंडलिंग
                          : असिंक/अवेट पैटर्न
                          : त्रुटि प्रबंधन
                          : नॉन-ब्लॉकिंग ऑपरेशन्स
        
    section त्रुटि प्रबंधन (30 मिनट)
        मजबूत एप्लिकेशन: ट्राई/कैच ब्लॉक्स
                    : उपयोगकर्ता-अनुकूल संदेश
                    : कोमल अपक्षय
                    : डिबगिंग तकनीकें
        
    section उन्नत पैटर्न (1 सप्ताह)
        पेशेवर विकास: कैशिंग रणनीतियाँ
                   : दर सीमांकन
                   : पुनः प्रयास तंत्र
                   : प्रदर्शन अनुकूलन
        
    section उत्पादन कौशल (1 महीना)
        उद्यम फीचर्स: सुरक्षा सर्वोत्तम प्रथाएँ
                   : API संस्करण
                   : निगरानी और लॉगिंग
                   : मापनीय संरचना

🛠️ आपका पूर्ण-स्टैक विकास टूलकिट सारांश

इस पाठ को पूरा करने के बाद, आपके पास अब है:

  • DOM मास्टरी: सटीक तत्व लक्ष्यीकरण और मैनिपुलेशन
  • स्टोरेज विशेषज्ञता: localStorage के साथ स्थायी डेटा प्रबंधन
  • API एकीकरण: वास्तविक समय डेटा फ़ेचिंग और प्रमाणीकरण
  • असिंक प्रोग्रामिंग: आधुनिक जावास्क्रिप्ट के साथ नॉन-ब्लॉकिंग ऑपरेशंस
  • त्रुटि हैंडलिंग: मजबूत एप्लिकेशन जो विफलताओं को सहजता से संभालते हैं
  • उपयोगकर्ता अनुभव: लोडिंग अवस्था, वैलिडेशन, और सुचारू इंटरैक्शंस
  • आधुनिक पैटर्न: fetch API, async/await, और ES6+ विशेषताएं

प्रोफेशनल कौशल सीखे गए: आपने पैटर्न लागू किए हैं जैसे:

  • वेब एप्लिकेशन: बाहरी डेटा स्रोतों के साथ सिंगल-पेज ऐप्स
  • मोबाइल विकास: API-चालित ऐप्स ऑफ़लाइन क्षमताओं के साथ
  • डेस्कटॉप सॉफ्टवेयर: Electron ऐप्स स्थायी स्टोरेज के साथ
  • एंटरप्राइज़ सिस्टम्स: प्रमाणीकरण, कैशिंग, और त्रुटि हैंडलिंग
  • आधुनिक फ्रेमवर्क: React/Vue/Angular डेटा प्रबंधन पैटर्न

अगला स्तर: आप उन्नत विषयों जैसे कैशिंग रणनीतियों, वास्तविक-समय WebSocket कनेक्शन, या जटिल स्टेट मैनेजमेंट को एक्सप्लोर करने के लिए तैयार हैं!

असाइनमेंट

Adopt an API


अस्वीकरण:
इस दस्तावेज़ का अनुवाद AI अनुवाद सेवा Co-op Translator का उपयोग करके किया गया है। जबकि हम सटीकता के लिए प्रयासरत हैं, कृपया ध्यान दें कि स्वचालित अनुवादों में त्रुटियाँ या असंगतियाँ हो सकती हैं। मूल दस्तावेज़ उसकी मातृ भाषा में ही अधिकारिक स्रोत माना जाना चाहिए। महत्वपूर्ण जानकारी के लिए, पेशेवर मानव अनुवाद की सलाह दी जाती है। इस अनुवाद के उपयोग से उत्पन्न किसी भी गलतफहमी या गलत व्याख्या के लिए हम उत्तरदायी नहीं हैं।