ब्राउज़र एक्सटेंशन प्रोजेक्ट भाग 3: पृष्ठभूमि कार्यों और प्रदर्शन के बारे में जानें
January 29, 2026 · View on GitHub
journey
title आपकी प्रदर्शन अनुकूलन यात्रा
section नींव
ब्राउज़र उपकरण सीखें: 3: Student
प्रोफाइलिंग समझें: 4: Student
बाधाओं की पहचान करें: 4: Student
section विस्तार की विशेषताएँ
रंग प्रणाली बनाएं: 4: Student
पृष्ठभूमि कार्य बनाएँ: 5: Student
आइकन गतिशील रूप से अपडेट करें: 5: Student
section अनुकूलन
प्रदर्शन की निगरानी करें: 5: Student
मुद्दों को डिबग करें: 4: Student
अनुभव को संशोधित करें: 5: Student
क्या आपने कभी सोचा है कि कुछ ब्राउजर एक्सटेंशन क्यों जल्दी और प्रतिक्रियाशील महसूस होते हैं जबकि दूसरे सुस्त कैसे लगते हैं? इसका रहस्य पर्दे के पीछे हो रही चीजों में छिपा है। जब उपयोगकर्ता आपके एक्सटेंशन के इंटरफ़ेस पर क्लिक करते हैं, तब पृष्ठभूमि में डेटा प्राप्त करने, आइकन अपडेट करने और सिस्टम संसाधनों का प्रबंधन करने वाली प्रक्रियाएं चुपचाप चल रही होती हैं।
यह ब्राउज़र एक्सटेंशन श्रृंखला का हमारा अंतिम पाठ है, और हम आपके कार्बन फुटप्रिंट ट्रैकर को सुचारू रूप से काम करने वाला बनाएंगे। आप डायनामिक आइकन अपडेट जोड़ेंगे और प्रदर्शन समस्याओं को तब पहचानना सीखेंगे जब वे बड़ी समस्या बनने से पहले हों। यह एक रेस कार को ट्यून करने जैसा है - छोटे-छोटे अनुकूलन सब कुछ चलाने के तरीके में बड़ा फर्क डाल सकते हैं।
जब हम समाप्त कर लेंगे, तो आपके पास एक पूर्ण एक्सटेंशन होगा और आप उन प्रदर्शन सिद्धांतों को समझेंगे जो अच्छे वेब ऐप्स को महान वेब ऐप्स से अलग करते हैं। आइए ब्राउज़र अनुकूलन की दुनिया में गोता लगाएँ।
प्री-लेक्चर क्विज़
परिचय
हमारे पिछले पाठों में, आपने एक फॉर्म बनाया, उसे API से जोड़ा, और असिंक्रोनस डेटा प्राप्ति से निपटा। आपका एक्सटेंशन अच्छे से आकार ले रहा है।
अब हमें अंतिम स्पर्श जोड़ने हैं - जैसे कि एक्सटेंशन आइकन को कार्बन डेटा के आधार पर रंग बदलना। यह मुझे याद दिलाता है कि NASA को अपोलो अंतरिक्ष यान पर हर सिस्टम को अनुकूलित करना पड़ा था। वे किसी भी बेकार चक्र या मेमोरी की व्यय सहन नहीं कर सकते थे क्योंकि प्रदर्शन पर जीवन निर्भर था। जबकि हमारा ब्राउज़र एक्सटेंशन इतना महत्वपूर्ण नहीं है, वही सिद्धांत लागू होते हैं - कुशल कोड बेहतर उपयोगकर्ता अनुभव बनाता है।
mindmap
root((प्रदर्शन और पृष्ठभूमि कार्य))
Browser Performance
Rendering Pipeline
Asset Optimization
DOM Manipulation
JavaScript Execution
Profiling Tools
Developer Tools
Performance Tab
Timeline Analysis
Bottleneck Detection
Extension Architecture
Background Scripts
Content Scripts
Message Passing
Icon Management
Optimization Strategies
Code Splitting
Lazy Loading
Caching
Resource Compression
Visual Feedback
Dynamic Icons
Color Coding
Real-time Updates
User Experience
वेब प्रदर्शन के मूल तत्व
जब आपका कोड कुशलतापूर्वक चलता है, तो लोग वास्तव में अंतर महसूस कर सकते हैं। आप जानते हैं कि वह क्षण जब कोई पेज तुरंत लोड हो जाता है या एनीमेशन सुचारू रूप से चलता है? यही अच्छा प्रदर्शन है।
प्रदर्शन केवल गति के बारे में नहीं है - यह सहज और बाधारहित वेब अनुभव बनाने के बारे में है। कंप्यूटिंग के शुरुआती दिनों में, ग्रेस हॉपर ने प्रसिद्ध रूप से अपनी मेज पर एक नैनोसेकंड (लगभग एक फुट लंबा तार) रखा था ताकि दिखाया जा सके कि एक अरबवें हिस्से में प्रकाश कितना दूर चलता है। यह उनके लिए यह समझाने का तरीका था कि कंप्यूटिंग में हर माइक्रोसेकंड क्यों महत्वपूर्ण है। आइए उन पता लगाने वाले उपकरणों को देखें जो आपको समझने में मदद करते हैं कि क्या चीज़ धीमी कर रही है।
"वेबसाइट प्रदर्शन दो चीजों के बारे में है: पेज कितनी तेजी से लोड होता है, और उस पर कोड कितनी तेजी से चलता है।" -- Zack Grossbart
यह विषय कि आपकी वेबसाइट को हर तरह के उपकरणों, हर तरह के उपयोगकर्ताओं के लिए, हर परिस्थिति में तेज़ कैसे बनाया जाए, सहज रूप से बहुत विशाल है। जब आप एक मानक वेब प्रोजेक्ट या ब्राउज़र एक्सटेंशन बनाते हैं, तो ध्यान रखने के लिए कुछ बातें यहाँ दी गई हैं।
आपकी साइट को अनुकूलित करने का पहला कदम है यह समझना कि वास्तव में पर्दे के नीचे क्या हो रहा है। सौभाग्य से, आपके ब्राउज़र में शक्तिशाली पता लगाने वाले उपकरण अंतर्निहित होते हैं।
flowchart LR
A[HTML] --> B[पार्स करें]
B --> C[DOM ट्री]
D[CSS] --> E[पार्स करें]
E --> F[CSSOM]
G[JavaScript] --> H[निष्पादित करें]
C --> I[रेंडर ट्री]
F --> I
H --> I
I --> J[लेआउट]
J --> K[पेंट]
K --> L[सम्मिलित करें]
L --> M[डिस्प्ले]
subgraph "महत्वपूर्ण रेंडरिंग पथ"
N["1. HTML पार्स करें"]
O["2. CSS पार्स करें"]
P["3. JS निष्पादित करें"]
Q["4. रेंडर ट्री बनाएं"]
R["5. एलिमेंट्स लेआउट करें"]
S["6. पिक्सेल पेंट करें"]
T["7. लेयर्स सम्मिलित करें"]
end
style M fill:#e8f5e8
style I fill:#fff3e0
style H fill:#ffebee
एज में डेवलपर टूल खोलने के लिए, ऊपर दाईं ओर तीन डॉट्स पर क्लिक करें, फिर More Tools > Developer Tools पर जाएं। या कीबोर्ड शॉर्टकट का उपयोग करें: Windows पर Ctrl + Shift + I या Mac पर Option + Command + I। वहां पहुंचने के बाद, Performance टैब पर क्लिक करें - यहीं आपकी जांच होगी।
यहाँ आपका प्रदर्शन जांच उपकरण किट है:
- खोलें Developer Tools (इन्हें आप एक डेवलपर के रूप में हमेशा उपयोग करेंगे!)
- जाएं Performance टैब पर - इसे अपने वेब ऐप के फिटनेस ट्रैकर के रूप में सोचें
- दबाएं रिकॉर्ड बटन और देखें कि आपका पेज कैसे काम करता है
- अध्ययन करें परिणामों को यह पता लगाने के लिए कि क्या चीज़ धीमी कर रही है
आइए इसे आज़माएँ। कोई वेबसाइट खोलें (Microsoft.com अच्छा विकल्प है) और 'रिकॉर्ड' बटन पर क्लिक करें। अब पेज रिफ्रेश करें और प्रोफाइलर को सब कुछ कैप्चर करते देखें। जब आप रिकॉर्डिंग बंद करेंगे, तो आपको ब्राउज़र के 'स्क्रिप्ट', 'रेंडर' और 'पेंट' करने के विस्तृत विवरण दिखाई देंगे। यह मुझे याद दिलाता है कि कैसे मिशन कंट्रोल एक रॉकेट लॉन्च के दौरान हर सिस्टम की निगरानी करता है - आपको वास्तविक समय के डेटा मिलते हैं कि क्या हो रहा है और कब।

✅ Microsoft Documentation में और भी बहुत जानकारी है यदि आप गहराई से जानना चाहते हैं
प्रो टिप: परीक्षण से पहले अपने ब्राउज़र कैश को क्लियर करें ताकि आप देख सकें कि आपकी साइट नए विज़िटर के लिए कैसे प्रदर्शन करती है - यह आमतौर पर पुनः उपयोगकर्ताओं से काफी अलग होता है!
प्रोफ़ाइल टाइमलाइन के तत्वों को चुनकर उन घटनाओं पर ज़ूम करें जो पेज लोड के दौरान होती हैं।
प्रोफ़ाइल टाइमलाइन का हिस्सा चुनकर अपने पेज के प्रदर्शन का स्नैपशॉट प्राप्त करें और सारांश पैन देखें:

देखें कि ईवेंट लॉग पैनल में कोई घटना 15 मिलीसेकंड से अधिक समय तो नहीं ले रही है:

✅ अपने प्रोफाइलर को जानें! इस साइट पर डेवलपर टूल खोलें और देखें कि क्या कोई बाधा है। सबसे धीमा लोड होने वाला संसाधन कौन सा है? सबसे तेज़?
flowchart TD
A[DevTools खोलें] --> B[परफॉर्मेंस टैब पर जाएँ]
B --> C[रिकॉर्ड बटन क्लिक करें]
C --> D[कार्य करें]
D --> E[रिकॉर्डिंग बंद करें]
E --> F{परिणामों का विश्लेषण करें}
F --> G[टाइमलाइन जांचें]
F --> H[नेटवर्क समीक्षा करें]
F --> I[स्क्रिप्ट्स की जांच करें]
F --> J[पेंट इवेंट्स पहचानें]
G --> K{लंबे कार्य?}
H --> L{बड़ी संपत्तियाँ?}
I --> M{रेंडर ब्लॉकिंग?}
J --> N{महंगे पेंट्स?}
K -->|हाँ| O[JavaScript अनुकूलित करें]
L -->|हाँ| P[संपत्तियों को संपीड़ित करें]
M -->|हाँ| Q[Async/Defer जोड़ें]
N -->|हाँ| R[शैलियाँ सरल बनाएं]
O --> S[फिर से परीक्षण करें]
P --> S
Q --> S
R --> S
style A fill:#e1f5fe
style F fill:#fff3e0
style S fill:#e8f5e8
प्रोफाइलिंग करते समय क्या देखें
प्रोफाइलर चलाना तो बस शुरुआत है - असली कौशल यह जानना है कि वे रंगीन चार्ट वास्तव में क्या बता रहे हैं। चिंता मत करें, आप इन्हें पढ़ना सीख जाएंगे। अनुभवी डेवलपर्स समस्या बनने से पहले चेतावनी संकेतों को पहचानना सीख चुके हैं।
आइए सामान्य संदेहियों की बात करें - वे प्रदर्शन की समस्याएँ जो वेब प्रोजेक्ट्स में चुपके से आ जाती हैं। जैसे मैरी क्यूरी को अपनी प्रयोगशाला में रेडिएशन स्तर सावधानी से मॉनीटर करना पड़ता था, वैसे ही हमें कुछ पैटर्न देखना होगा जो समस्या की शुरुआत बताते हैं। इन्हें जल्दी पकड़ना आपको (और आपके उपयोगकर्ताओं को) बहुत सारी निराशा से बचाएगा।
संसाधन आकार: वेबसाइटें वर्षों में "भारी" होती जा रही हैं, और इसका बड़ा हिस्सा छवियों से आता है। ऐसा है जैसे हम अपनी डिजिटल सूटकेस में लगातार अधिक और अधिक सामान भर रहे हों।
✅ Internet Archive देखें कि पेज के आकार समय के साथ कैसे बढ़े हैं - यह काफी जानकारीपूर्ण है।
संसाधनों को अनुकूलित रखने के तरीके:
- कंप्रेस करें उन छवियों को! आधुनिक फॉर्मेट जैसे WebP फ़ाइल आकार को काफी कम कर सकते हैं
- हर डिवाइस के लिए सही छवि आकार परोसें - बड़े डेस्कटॉप इमेजेस फोन पर भेजने की जरूरत नहीं
- अपना CSS और JavaScript मिनीफाई करें - हर बाइट मायने रखता है
- लेज़ी लोडिंग का उपयोग करें ताकि चित्र तभी डाउनलोड हों जब उपयोगकर्ता वास्तव में नीचे स्क्रॉल करें
DOM ट्रैवर्सल: ब्राउज़र को आपके लिखे गए कोड के आधार पर अपना डॉक्यूमेंट ऑब्जेक्ट मॉडल बनाना होता है, इसलिए अच्छा प्रदर्शन बनाने के लिए आवश्यक टैग ही रखना चाहिए और केवल वही स्टाइलिंग करनी चाहिए जो पेज जरूरत हो। इस बात तक, पेज से जुड़ा अतिरिक्त CSS भी अनुकूलित किया जा सकता है; केवल एक पेज पर उपयोग होने वाले स्टाइल्स मुख्य स्टाइलशीट में शामिल नहीं होने चाहिए।
DOM अनुकूलन के प्रमुख रणनीतियाँ:
- HTML एलिमेंट्स और नेस्टिंग स्तरों की संख्या न्यूनतम करना
- अनुपयोग किए गए CSS नियम हटाना और स्टाइलशीट्स का कुशल समेकन
- CSS को इस तरह व्यवस्थित करना कि प्रत्येक पेज के लिए केवल आवश्यक लोड हो
- ब्रााउसर्स के बेहतर पार्सिंग के लिए HTML को सेमान्टिक रूप से संरचित करना
JavaScript: हर JavaScript डेवलपर को 'रेंडर-ब्लॉकिंग' स्क्रिप्ट्स पर ध्यान देना चाहिए जिन्हें DOM पार्सिंग और पेंटिंग से पहले लोड किया जाना जरूरी होता है। अपने इनलाइन स्क्रिप्ट्स में defer का उपयोग करने पर विचार करें (जैसा Terrarium मॉड्यूल में किया जाता है)।
आधुनिक JavaScript अनुकूलन तकनीकें:
deferएट्रिब्यूट का उपयोग करके स्क्रिप्ट्स DOM पार्सिंग के बाद लोड करना- कोड स्प्लिटिंग लागू करना ताकि केवल आवश्यक JavaScript लोड हो
- गैर-महत्वपूर्ण कार्यक्षमता के लिए लेज़ी लोडिंग उपयोग करना
- जहां संभव हो, भारी लाइब्रेरी और फ्रेमवर्क के उपयोग को कम करना
✅ आप कुछ साइटों को Site Speed Test वेबसाइट पर आज़मा सकते हैं ताकि साइट प्रदर्शन जाँच के सामान्य तरीकों को जान सकें।
🔄 शैक्षिक जाँच-पड़ताल
प्रदर्शन की समझ: एक्सटेंशन फीचर्स बनाने से पहले सुनिश्चित करें कि आप:
- ✅ HTML से पिक्सेल तक के क्रिटिकल रेंडरिंग पाथ को समझा सकते हैं
- ✅ वेब ऐप में सामान्य प्रदर्शन बाधाओं की पहचान कर सकते हैं
- ✅ ब्राउज़र डेवलपर टूल के उपयोग से पेज प्रदर्शन का प्रोफाइलिंग कर सकते हैं
- ✅ समझ सकते हैं कि संसाधन का आकार और DOM जटिलता गति को कैसे प्रभावित करती है
त्वरित आत्म-परीक्षा: जब आपके पास रेंडर-ब्लॉकिंग JavaScript होता है तब क्या होता है? उत्तर: ब्राउज़र को स्क्रिप्ट डाउनलोड और निष्पादित करना पड़ता है इससे पहले कि वह HTML पार्स करना और पेज रेंडर करना जारी रख सके
वास्तविक दुनिया में प्रदर्शन प्रभाव:
- 100ms देरी: उपयोगकर्ता धीमा महसूस करते हैं
- 1 सेकंड देरी: उपयोगकर्ता ध्यान खोने लगते हैं
- 3+ सेकंड: 40% उपयोगकर्ता पेज छोड़ देते हैं
- मोबाइल नेटवर्क: प्रदर्शन और भी महत्वपूर्ण होता है
अब जब आपके पास यह विचार है कि ब्राउज़र उन संसाधनों को कैसे रेंडर करता है जो आप उसे भेजते हैं, तो आइए वे अंतिम चीजें देखें जो आपके एक्सटेंशन को पूरा करने के लिए करनी हैं:
रंग गणना करने वाला फ़ंक्शन बनाएं
अब हम एक ऐसा फ़ंक्शन बनाएंगे जो संख्यात्मक डेटा को अर्थपूर्ण रंगों में बदलता है। इसे ट्रैफिक लाइट सिस्टम की तरह सोचें - हरित (ग्रीन) साफ ऊर्जा के लिए, लाल ज़्यादा कार्बन तीव्रता के लिए।
यह फ़ंक्शन हमारी API से CO2 डेटा लेकर यह निर्धारित करेगा कि पर्यावरणीय प्रभाव का सबसे उपयुक्त रंग कौन सा है। यह वैसा ही है जैसे वैज्ञानिक जटिल डेटा पैटर्न को विज़ुअलाइज़ करने के लिए हीट मैप्स में रंग कोडिंग करते हैं - महासागर तापमान से लेकर तारा निर्माण तक। इसे /src/index.js में जोड़ें, ठीक उन const वेरिएबल्स के बाद जो हमने पहले सेट किए थे:
flowchart LR
A[CO2 मान] --> B[सबसे नजदीकी स्केल पॉइंट खोजें]
B --> C[स्केल इंडेक्स प्राप्त करें]
C --> D[रंग से मैप करें]
D --> E[बैकग्राउंड को भेजें]
subgraph "रंग मापक"
F["0-150: हरा (स्वच्छ)"]
G["150-600: पीला (मध्यम)"]
H["600-750: नारंगी (उच्च)"]
I["750+: भूरा (बहुत उच्च)"]
end
subgraph "संदेश पासिंग"
J[सामग्री स्क्रिप्ट]
K[chrome.runtime.sendMessage]
L[बैकग्राउंड स्क्रिप्ट]
M[आइकन अपडेट]
end
style A fill:#e1f5fe
style D fill:#e8f5e8
style E fill:#fff3e0
function calculateColor(value) {
// CO2 तीव्रता पैमाना परिभाषित करें (ग्राम प्रति kWh)
const co2Scale = [0, 150, 600, 750, 800];
// हरे (स्वच्छ) से गहरे भूरे (उच्च कार्बन) तक संबंधित रंग
const colors = ['#2AA364', '#F5EB4D', '#9E4229', '#381D02', '#381D02'];
// हमारे इनपुट के सबसे निकटतम पैमाना मान खोजें
const closestNum = co2Scale.sort((a, b) => {
return Math.abs(a - value) - Math.abs(b - value);
})[0];
console.log(`${value} is closest to ${closestNum}`);
// रंग मानचित्रण के लिए सूचकांक खोजें
const num = (element) => element > closestNum;
const scaleIndex = co2Scale.findIndex(num);
const closestColor = colors[scaleIndex];
console.log(scaleIndex, closestColor);
// पृष्ठभूमि स्क्रिप्ट को रंग अद्यतन संदेश भेजें
chrome.runtime.sendMessage({ action: 'updateIcon', value: { color: closestColor } });
}
इस चालाक छोटे फ़ंक्शन का विश्लेषण:
- दो एरे सेट करता है - एक CO2 स्तर के लिए, दूसरा रंगों के लिए (ग्रीन = साफ, ब्राउन = गंदा!)
- क्लोज़ेस्ट मैच खोजता है हमारे वास्तविक CO2 मान के लिए कुछ स्मार्ट एरे सॉर्टिंग का उपयोग करके
- मेल खाते रंग को प्राप्त करता है findIndex() मेथड का उपयोग करके
- Chrome के बैकग्राउंड स्क्रिप्ट को संदेश भेजता है हमारे चुने हुए रंग के साथ
- टेम्पलेट लिटरेल्स (बैकटिक्स) का उपयोग करता है स्ट्रिंग फॉर्मेटिंग के लिए साफ-सुथरा
- const घोषणाओं से सब कुछ व्यवस्थित रखता है
chrome.runtime API आपके एक्सटेंशन की नसों की तरह है - यह सभी पर्दे के पीछे की संचार और कार्यों को संभालता है:
"chrome.runtime API का उपयोग पृष्ठभूमि पेज को प्राप्त करने, मैनिफेस्ट के विवरण लौटाने, और ऐप या एक्सटेंशन लाइफसायकल में घटनाओं को सुनने और प्रतिक्रिया देने के लिए करें। आप इस API का उपयोग URL के सापेक्ष पथ को पूर्ण योग्य URL में बदलने के लिए भी कर सकते हैं।"
Chrome Runtime API क्यों उपयोगी है:
- आपके एक्सटेंशन के विभिन्न भागों को बातचीत करने देता है
- यूजर इंटरफ़ेस को फ्रीज किए बिना पृष्ठभूमि कार्यों को संभालता है
- आपके एक्सटेंशन के लाइफसायकल इवेंट्स का प्रबंधन करता है
- स्क्रिप्ट्स के बीच संदेश पारित करना बहुत आसान बनाता है
✅ यदि आप यह ब्राउज़र एक्सटेंशन Edge के लिए विकसित कर रहे हैं, तो यह आश्चर्यचकित कर सकता है कि आप एक क्रोम API का उपयोग कर रहे हैं। नया Edge ब्राउज़र संस्करण Chromium ब्राउज़र इंजन पर चलता है, इसलिए आप इन उपकरणों का लाभ उठा सकते हैं।
architecture-beta
group browser(logos:chrome)[ब्राउज़र]
service popup(logos:html5)[पॉपअप UI] in browser
service content(logos:javascript)[कंटेंट स्क्रिप्ट] in browser
service background(database)[बैकग्राउंड स्क्रिप्ट] in browser
service api(logos:api)[बाहरी API] in browser
popup:R -- L:content
content:R -- L:background
background:T -- B:api
content:T -- B:api
junction junctionCenter in browser
popup:R -- L:junctionCenter
junctionCenter:R -- L:background
प्रो टिप: यदि आप किसी ब्राउज़र एक्सटेंशन को प्रोफाइल करना चाहते हैं, तो अपने एक्सटेंशन के अंदर से डेवलपर टूल लॉन्च करें, क्योंकि यह उसका अपना अलग ब्राउज़र इंस्टेंस होता है। इससे आपको एक्सटेंशन-विशिष्ट प्रदर्शन मीट्रिक्स तक पहुँच मिलती है।
डिफ़ॉल्ट आइकन रंग सेट करें
असल डेटा प्राप्त करने से पहले, आइए अपने एक्सटेंशन को एक शुरुआती बिंदु दें। कोई भी खाली या टूटा हुआ आइकन देखकर खुश नहीं होता। हम एक हरा रंग सेट करेंगे ताकि उपयोगकर्ता इंस्टॉल करते ही एक्सटेंशन काम कर रहा हो यह जान सकें।
अपने init() फ़ंक्शन में, उस डिफ़ॉल्ट हरे आइकन को सेट करें:
chrome.runtime.sendMessage({
action: 'updateIcon',
value: {
color: 'green',
},
});
यह प्रारंभिक सेटअप क्या करता है:
- डिफ़ॉल्ट स्थिति के रूप में एक तटस्थ हरा रंग सेट करता है
- एक्सटेंशन लोड होते ही तत्काल विज़ुअल फीडबैक प्रदान करता है
- बैकग्राउंड स्क्रिप्ट के साथ संचार पैटर्न स्थापित करता है
- उपयोगकर्ताओं को डेटा लोड होने से पहले कार्यात्मक एक्सटेंशन दिखाता है
फ़ंक्शन कॉल करें, कॉल निष्पादित करें
अब आइए सब कुछ जोड़ते हैं ताकि जब ताजा CO2 डेटा आए, तो आपका आइकन स्वचालित रूप से सही रंग में अपडेट हो जाए। यह किसी इलेक्ट्रॉनिक डिवाइस में अंतिम सर्किट जोड़ने जैसा है - अचानक सारे घटक एक सिस्टम के रूप में काम करने लगते हैं।
API से CO2 डेटा मिलने के तुरंत बाद यह लाइन जोड़ें:
// API से CO2 डेटा प्राप्त करने के बाद
// let CO2 = data.data[0].intensity.actual;
calculateColor(CO2);
यह एकीकरण क्या करता है:
- API डेटा प्रवाह को विज़ुअल संकेतक प्रणाली से जोड़ता है
- जब नया डेटा आता है तो स्वचालित रूप से आइकन अपडेट करता है
- वर्तमान कार्बन तीव्रता पर आधारित वास्तविक समय विज़ुअल फीडबैक सुनिश्चित करता है
- डेटा प्राप्ति और प्रदर्शन लॉजिक के बीच अलगाव बनाए रखता है
और अंत में, /dist/background.js में, इन पृष्ठभूमि क्रिया कॉल्स के लिए श्रोता जोड़ें:
// कंटेंट स्क्रिप्ट से संदेश सुनें
chrome.runtime.onMessage.addListener(function (msg, sender, sendResponse) {
if (msg.action === 'updateIcon') {
chrome.action.setIcon({ imageData: drawIcon(msg.value) });
}
});
// Canvas API का उपयोग करके डायनेमिक आइकन बनाएं
// एनर्जी लॉलीपॉप एक्सटेंशन से उधार लिया गया - बढ़िया फीचर!
function drawIcon(value) {
// बेहतर प्रदर्शन के लिए एक ऑफस्क्रीन कैनवास बनाएं
const canvas = new OffscreenCanvas(200, 200);
const context = canvas.getContext('2d');
// कार्बन तीव्रता दर्शाने के लिए एक रंगीन वृत्त बनाएं
context.beginPath();
context.fillStyle = value.color;
context.arc(100, 100, 50, 0, 2 * Math.PI);
context.fill();
// ब्राउज़र आइकन के लिए इमेज डेटा लौटाएं
return context.getImageData(50, 50, 100, 100);
}
यह बैकग्राउंड स्क्रिप्ट क्या करता है:
- मुख्य स्क्रिप्ट से संदेश सुनता है (जैसे एक रिसेप्शनिस्ट कॉल उठाता हो)
- उन 'updateIcon' अनुरोधों को संसाधित करता है जो टूलबार आइकन बदलने को कहते हैं
- Canvas API का उपयोग करते हुए नए आइकन बना चलता है
- एक सरल रंगीन घेरा बनाता है जो वर्तमान कार्बन तीव्रता दिखाता है
- आपके ब्राउज़र टूलबार को ताजगी से अपडेट करता है
- स्मूद प्रदर्शन के लिए OffscreenCanvas का उपयोग करता है (कोई UI रोकावट नहीं)
✅ आप स्पेस गेम पाठों में Canvas API के बारे में और जानेंगे।
sequenceDiagram
participant CS as कंटेंट स्क्रिप्ट
participant BG as बैकग्राउंड स्क्रिप्ट
participant Canvas as ऑफस्क्रीन कैनवास
participant Browser as ब्राउज़र आइकन
CS->>BG: sendMessage({action: 'updateIcon', color})
BG->>Canvas: new OffscreenCanvas(200, 200)
Canvas->>Canvas: getContext('2d')
Canvas->>Canvas: beginPath() + fillStyle + arc()
Canvas->>Canvas: fill() + getImageData()
Canvas->>BG: इमेज डेटा लौटाएं
BG->>Browser: chrome.action.setIcon(imageData)
Browser->>Browser: टूलबार आइकन अपडेट करें
🔄 शैक्षिक जाँच-पड़ताल
पूरा एक्सटेंशन समझना: पूरे सिस्टम में दक्षता की पुष्टि करें:
- ✅ विभिन्न एक्सटेंशन स्क्रिप्ट्स में संदेश पारित कैसे होता है?
- ✅ प्रदर्शन के लिए नियमित Canvas के बजाय OffscreenCanvas का उपयोग क्यों करते हैं?
- ✅ क्रोम रनटाइम API एक्सटेंशन आर्किटेक्चर में क्या भूमिका निभाता है?
- ✅ कलर कैलकुलेशन एल्गोरिद्म डेटा को विज़ुअल फीडबैक में कैसे मैप करता है?
परफॉर्मेंस विचार-विमर्श: आपका एक्सटेंशन अब प्रदर्शित करता है:
- प्रभावी मैसेजिंग: स्क्रिप्ट संदर्भों के बीच साफ-सुथरा संचार
- ऑप्टिमाइज़्ड रेंडरिंग: OffscreenCanvas UI ब्लॉकिंग को रोकता है
- रियल-टाइम अपडेट्स: लाइव डेटा के आधार पर डायनेमिक आइकन परिवर्तन
- मेमोरी प्रबंधन: उचित सफाई और संसाधन प्रबंधन
अपने एक्सटेंशन का परीक्षण करने का समय:
npm run buildके साथ सब कुछ बिल्ड करें- ब्राउज़र में अपना एक्सटेंशन रीलोड करें (यह स्टेप न भूलें)
- अपना एक्सटेंशन खोलें और देखें कि आइकन के रंग कैसे बदलते हैं
- देखें कि यह दुनिया भर के असली कार्बन डेटा पर कैसे प्रतिक्रिया देता है
अब आप एक नज़र में जान पाएंगे कि वह कपड़े धोने का समय अच्छा है या आपको साफ-सुथरी ऊर्जा के लिए इंतजार करना चाहिए। आपने अभी कुछ वास्तव में उपयोगी बनाया है और ब्राउज़र के प्रदर्शन के बारे में भी जाना है।
GitHub Copilot एजेंट चुनौती 🚀
एजेंट मोड का उपयोग करके निम्नलिखित चुनौती पूरी करें:
विवरण: ब्राउज़र एक्सटेंशन की प्रदर्शन निगरानी क्षमताओं को बढ़ाएं और एक फीचर जोड़ें जो एक्सटेंशन के विभिन्न घटकों के लोड समय को ट्रैक और प्रदर्शित करता है।
प्रॉम्प्ट: एक प्रदर्शन निगरानी प्रणाली बनाएं जो API से CO2 डेटा प्राप्त करने, रंगों की गणना करने, और आइकन को अपडेट करने में लगने वाले समय को मापती और लॉग करती हो। एक फ़ंक्शन performanceTracker जोड़ें जो Performance API का उपयोग करके इन ऑपरेशनों को मापे और परिणामों को ब्राउज़र कॉन्सोल में टाइमस्टैम्प्स और अवधि मीट्रिक्स के साथ प्रदर्शित करे।
agent मोड के बारे में अधिक जानें।
🚀 चुनौती
यहाँ एक रोचक जासूसी मिशन है: कुछ ऐसे ओपन सोर्स वेबसाइट्स चुनें जो वर्षों से मौजूद हैं (जैसे Wikipedia, GitHub, या Stack Overflow) और उनके कमिट इतिहास में उत्खनन करें। क्या आप पता लगा सकते हैं कि उन्होंने प्रदर्शन सुधार कहाँ किए? कौन सी समस्याएँ बार-बार उभरती रहीं?
आपकी जांच करने की विधि:
- कमिट संदेशों में "optimize," "performance," या "faster" जैसे शब्द खोजें
- पैटर्न देखें - क्या वे एक ही प्रकार की समस्याएँ लगातार ठीक कर रहे हैं?
- सामान्य कारणों की पहचान करें जो वेबसाइट को स्लो करते हैं
- अपने निष्कर्ष साझा करें - अन्य डेवलपर्स असली दुनिया के उदाहरणों से सीखते हैं
पोस्ट-लेक्चर क्विज़
समीक्षा एवं आत्म-अध्ययन
परफॉर्मेंस न्यूज़लेटर के लिए साइन अप करने पर विचार करें।
ब्राउज़र के वेब टूल्स में परफॉर्मेंस टैब के जरिए देखें कि ब्राउज़र वेब परफॉर्मेंस को कैसे मापते हैं। क्या आपको कोई मुख्य अंतर दिखाई देते हैं?
⚡ अगले 5 मिनट में आप क्या कर सकते हैं
- ब्राउज़र टास्क मैनेजर खोलें (Chrome में Shift+Esc) और एक्सटेंशन संसाधन उपयोग देखें
- DevTools के Performance टैब में वेबपेज प्रदर्शन रिकॉर्ड और विश्लेषण करें
- ब्राउज़र के Extensions पेज पर देखें कि कौन से एक्सटेंशन्स स्टार्टअप समय प्रभावित करते हैं
- अस्थायी रूप से एक्सटेंशन्स को डिसेबल करके प्रदर्शन में फर्क देखें
🎯 इस घंटे में आप क्या हासिल कर सकते हैं
- पोस्ट-लेसन क्विज़ पूरा करें और परफॉर्मेंस अवधारणाएँ समझें
- अपने ब्राउज़र एक्सटेंशन के लिए बैकग्राउंड स्क्रिप्ट लागू करें
- कुशल बैकग्राउंड कार्यों के लिए browser.alarms सीखें
- कंटेंट स्क्रिप्ट्स और बैकग्राउंड स्क्रिप्ट्स के बीच मैसेज पासिंग का अभ्यास करें
- अपने एक्सटेंशन के संसाधन उपयोग को मापें और ऑप्टिमाइज़ करें
📅 आपका सप्ताहभर का परफॉर्मेंस सफर
- बैकग्राउंड फ़ंक्शनालिटी के साथ उच्च-प्रदर्शन ब्राउज़र एक्सटेंशन बनाएं
- सर्विस वर्कर्स और आधुनिक एक्सटेंशन आर्किटेक्चर में महारत हासिल करें
- कुशल डेटा सिंक्रोनाइज़ेशन और कैशिंग रणनीतियाँ लागू करें
- एक्सटेंशन परफॉर्मेंस के लिए उन्नत डिबगिंग तकनीक सीखें
- अपनी एक्सटेंशन को कार्यक्षमता और संसाधन दक्षता दोनों के लिए ऑप्टिमाइज़ करें
- एक्सटेंशन परफॉर्मेंस परिदृश्यों के लिए व्यापक परीक्षण बनाएँ
🌟 आपकी एक महीने की ऑप्टिमाइज़ेशन महारत
- एंटरप्राइज़-ग्रेड ब्राउज़र एक्सटेंशन्स बनाएं जो बेहतर प्रदर्शन दिखाएं
- वेब वर्कर्स, सर्विस वर्कर्स, और आधुनिक वेब प्रदर्शन के बारे में जानें
- प्रदर्शन अनुकूलन पर केंद्रित ओपन सोर्स प्रोजेक्ट्स में योगदान दें
- ब्राउज़र आंतरिक संरचनाओं और उन्नत डिबगिंग तकनीकों में दक्षता हासिल करें
- प्रदर्शन निगरानी उपकरण और सर्वोत्तम प्रथाओं के गाइड बनाएं
- एक प्रदर्शन विशेषज्ञ बनें जो वेब अनुप्रयोगों को अनुकूलित करने में मदद करता है
🎯 आपका ब्राउज़र एक्सटेंशन मास्टरी टाइमलाइन
timeline
title पूर्ण एक्सटेंशन विकास प्रगति
section प्रदर्शन मूल बातें (20 मिनट)
ब्राउज़र प्रोफाइलिंग: देवटूल्स महारत
: टाइमलाइन विश्लेषण
: बॉटलनेक पहचान
: क्रिटिकल रेंडरिंग पथ
section पृष्ठभूमि कार्य (25 मिनट)
एक्सटेंशन आर्किटेक्चर: संदेश पारगमन
: पृष्ठभूमि स्क्रिप्ट्स
: रनटाइम एपीआई उपयोग
: क्रॉस-कॉन्टेक्स्ट संचार
section दृश्य प्रतिक्रिया (30 मिनट)
डायनामिक यूआई: रंग गणना एल्गोरिदम
: कैनवास एपीआई एकीकरण
: आइकन जनरेशन
: रियल-टाइम अपडेट्स
section प्रदर्शन अनुकूलन (35 मिनट)
कुशल कोड: असिंक्रोनस ऑपरेशंस
: मेमोरी प्रबंधन
: संसाधन सफाई
: प्रदर्शन निरीक्षण
section उत्पादन के लिए तैयार (45 मिनट)
पालिश और परीक्षण: क्रॉस-ब्राउज़र संगतता
: त्रुटि हैंडलिंग
: उपयोगकर्ता अनुभव
: प्रदर्शन सत्यापन
section उन्नत सुविधाएँ (1 सप्ताह)
एक्सटेंशन इकोसिस्टम: क्रोम वेब स्टोर
: उपयोगकर्ता प्रतिक्रिया
: एनालिटिक्स एकीकरण
: अपडेट प्रबंधन
section पेशेवर विकास (2 सप्ताह)
उद्यम एक्सटेंशंस: टीम सहयोग
: कोड समीक्षा
: सीआई/सीडी पाइपलाइंस
: सुरक्षा ऑडिट
section विशेषज्ञ महारत (1 महीना)
प्लेटफॉर्म विशेषज्ञता: उन्नत क्रोम एपीआई
: प्रदर्शन अनुकूलन
: आर्किटेक्चर पैटर्न
: ओपन सोर्स योगदान
🛠️ आपका संपूर्ण एक्सटेंशन विकास टूलकिट
इस त्रयी को पूरा करने के बाद, आपने महारत हासिल की है:
- ब्राउज़र आर्किटेक्चर: एक्सटेंशन्स ब्राउज़र सिस्टम्स के साथ कैसे एकीकृत होते हैं, इसकी गहरी समझ
- परफॉर्मेंस प्रोफाइलिंग: डेवलपर टूल्स का उपयोग करके बॉटलनेक्स पहचानना और सुधारना
- एसिंक्रोनस प्रोग्रामिंग: प्रतिक्रियाशील, नॉन-ब्लॉकिंग ऑपरेशन्स के लिए आधुनिक JavaScript पैटर्न्स
- API इंटीग्रेशन: प्रमाणीकरण और त्रुटि प्रबंधन के साथ बाहरी डेटा प्राप्त करना
- विज़ुअल डिजाइन: डायनेमिक UI अपडेट्स और कैनवास-आधारित ग्राफिक्स निर्माण
- मैसेज पासिंग: एक्सटेंशन आर्किटेक्चर में स्क्रिप्ट्स के बीच संचार
- यूज़र एक्सपीरियंस: लोडिंग स्टेट्स, त्रुटि प्रबंधन, और सहज इंटरैक्शन
- प्रोडक्शन स्किल्स: रियल-वर्ल्ड डिप्लॉयमेंट के लिए टेस्टिंग, डिबगिंग, और ऑप्टिमाइजेशन
वास्तविक दुनिया के अनुप्रयोग: आपकी एक्सटेंशन विकास क्षमताएं सीधे लागू होती हैं:
- प्रोग्रेसिव वेब ऐप्स: समान आर्किटेक्चर और प्रदर्शन पैटर्न्स
- इलेक्ट्रॉन डेस्कटॉप ऐप्स: वेब तकनीकों का उपयोग करने वाले क्रॉस-प्लेटफॉर्म ऐप्स
- मोबाइल हाइब्रिड ऐप्स: Cordova/PhoneGap विकास वेब API का उपयोग करके
- एंटरप्राइज़ वेब ऐप्लिकेशन्स: जटिल डैशबोर्ड और उत्पादकता टूल्स
- क्रोम DevTools एक्सटेंशन्स: उन्नत डेवलपर टूलिंग और डिबगिंग
- वेब API इंटीग्रेशन: कोई भी एप्लिकेशन जो बाहरी सेवाओं से संवाद करता है
पेशेवर प्रभाव: अब आप कर सकते हैं:
- परिकल्पना से लेकर डिप्लॉयमेंट तक पूर्णत: पेशेवर ब्राउज़र एक्सटेंशन्स बनाएं
- प्रदर्शन प्रोफाइलिंग टूल्स का उपयोग करके वेब ऐप्लिकेशन के प्रदर्शन को बेहतर बनाएं
- स्केलेबल सिस्टम्स के आर्किटेक्चर के लिए उचित चिंता के पृथक्करण को लागू करें
- जटिल एसिंक्रोनस ऑपरेशन्स और跨-संदर्भ संचार को डिबग करें
- ओपन सोर्स एक्सटेंशन प्रोजेक्ट्स और ब्राउज़र मानकों में योगदान करें
अगले स्तर के अवसर:
- क्रोम वेब स्टोर डेवलपर: लाखों उपयोगकर्ताओं के लिए एक्सटेंशंस पब्लिश करें
- वेब प्रदर्शन इंजीनियर: अनुकूलन और उपयोगकर्ता अनुभव में विशेषज्ञता
- ब्राउज़र प्लेटफ़ॉर्म डेवलपर: ब्राउज़र इंजन विकास में योगदान दें
- एक्सटेंशन फ्रेमवर्क क्रिएटर: अन्य डेवलपर्स की मदद करने वाले टूल्स बनाएं
- डेवलपर रिलेशंस: शिक्षण और सामग्री निर्माण के जरिए ज्ञान साझा करें
🌟 उपलब्धि अनलॉक्ड: आपने एक संपूर्ण, कार्यात्मक ब्राउज़र एक्सटेंशन बनाया है जो पेशेवर विकास प्रथाओं और आधुनिक वेब मानकों को दर्शाता है!
असाइनमेंट
परफॉर्मेंस के लिए किसी साइट का विश्लेषण करें
अस्वीकरण:
यह दस्तावेज़ AI अनुवाद सेवा Co-op Translator का उपयोग करके अनूदित किया गया है। हम सटीकता के लिए प्रयास करते हैं, लेकिन कृपया ध्यान दें कि स्वचालित अनुवाद में त्रुटियाँ या असंगतियाँ हो सकती हैं। मूल दस्तावेज़ अपनी मूल भाषा में प्राधिकृत स्रोत माना जाना चाहिए। महत्वपूर्ण जानकारी के लिए, पेशेवर मानव अनुवाद की सलाह दी जाती है। इस अनुवाद के उपयोग से होने वाली किसी भी गलतफहमी या गलत व्याख्या के लिए हम जवाबदेह नहीं हैं।