# ब्राउजर एक्सटेन्सन प्रोजेक्ट भाग १: ब्राउजरको बारेमा सबै कुरा ![ब्राउजर स्केच नोट](../../../../translated_images/browser.60317c9be8b7f84adce43e30bff8d47a1ae15793beab762317b2bc6b74337c1a.ne.jpg) > स्केच नोट [वासिम चेघम](https://dev.to/wassimchegham/ever-wondered-what-happens-when-you-type-in-a-url-in-an-address-bar-in-a-browser-3dob) द्वारा ## प्रि-लेक्चर क्विज [प्रि-लेक्चर क्विज](https://ff-quizzes.netlify.app/web/quiz/23) ### परिचय ब्राउजर एक्सटेन्सनले ब्राउजरमा थप कार्यक्षमता थप्छ। तर, एउटा बनाउनु अघि, तपाईंले ब्राउजरले कसरी काम गर्छ भन्ने थोरै सिक्नुपर्छ। ### ब्राउजरको बारेमा यस पाठ श्रृंखलामा, तपाईं Chrome, Firefox, र Edge ब्राउजरमा काम गर्ने ब्राउजर एक्सटेन्सन बनाउन सिक्नुहुनेछ। यस भागमा, तपाईं ब्राउजरले कसरी काम गर्छ भन्ने पत्ता लगाउनुहुनेछ र ब्राउजर एक्सटेन्सनका तत्वहरू तयार गर्नुहुनेछ। तर ब्राउजर भनेको वास्तवमा के हो? यो एउटा सफ्टवेयर एप्लिकेसन हो जसले अन्तिम प्रयोगकर्तालाई सर्भरबाट सामग्री पहुँच गर्न र वेब पृष्ठहरूमा प्रदर्शन गर्न अनुमति दिन्छ। ✅ थोरै इतिहास: पहिलो ब्राउजर 'WorldWideWeb' भनिन्थ्यो र यो सर टिमोथी बर्नर्स-लीले १९९० मा बनाएका थिए। ![प्रारम्भिक ब्राउजरहरू](../../../../translated_images/earlybrowsers.d984b711cdf3a42ddac919d46c4b5ca7232f68ccfbd81395e04e5a64c0015277.ne.jpg) > केही प्रारम्भिक ब्राउजरहरू, [करेन म्याकग्रेन](https://www.slideshare.net/KMcGrane/week-4-ixd-history-personal-computing) मार्फत जब प्रयोगकर्ताले URL (Uniform Resource Locator) ठेगाना प्रयोग गरेर इन्टरनेटमा जडान गर्छ, सामान्यतया Hypertext Transfer Protocol मार्फत `http` वा `https` ठेगाना प्रयोग गरेर, ब्राउजरले वेब सर्भरसँग संवाद गर्छ र वेब पृष्ठ ल्याउँछ। यस बिन्दुमा, ब्राउजरको रेंडरिङ इन्जिनले यसलाई प्रयोगकर्ताको उपकरणमा प्रदर्शन गर्छ, जुन मोबाइल फोन, डेस्कटप, वा ल्यापटप हुन सक्छ। ब्राउजरहरूले सामग्री क्यास गर्ने क्षमता पनि राख्छन् ताकि प्रत्येक पटक सर्भरबाट पुनः प्राप्त गर्न नपरोस्। तिनीहरूले प्रयोगकर्ताको ब्राउजिङ गतिविधिको इतिहास रेकर्ड गर्न, 'कुकीहरू' भण्डारण गर्न सक्छन्, जुन साना डाटा बिटहरू हुन् जसले प्रयोगकर्ताको गतिविधि भण्डारण गर्न प्रयोग गरिन्छ, र थप। ब्राउजरहरूको बारेमा सम्झनुपर्ने एकदम महत्त्वपूर्ण कुरा भनेको तिनीहरू सबै एउटै हुँदैनन्! प्रत्येक ब्राउजरका आफ्नै बल र कमजोरीहरू छन्, र एक पेशेवर वेब डेभलपरले वेब पृष्ठहरूलाई क्रस-ब्राउजरमा राम्रो प्रदर्शन गर्न कसरी बनाउने भन्ने बुझ्न आवश्यक छ। यसमा मोबाइल फोनको सानो भ्यूपोर्टहरू ह्यान्डल गर्ने साथै अफलाइन प्रयोगकर्तालाई समर्थन गर्ने कुरा समावेश छ। एकदम उपयोगी वेबसाइट जुन तपाईंले आफ्नो मनपर्ने ब्राउजरमा बुकमार्क गर्नुपर्छ भनेको [caniuse.com](https://www.caniuse.com) हो। जब तपाईं वेब पृष्ठहरू बनाउँदै हुनुहुन्छ, caniuse को समर्थित प्रविधिहरूको सूची प्रयोग गर्नु धेरै उपयोगी हुन्छ ताकि तपाईंले आफ्नो प्रयोगकर्ताहरूलाई राम्रोसँग समर्थन गर्न सक्नुहुन्छ। ✅ तपाईंको वेब साइटको प्रयोगकर्ता आधारमा कुन ब्राउजरहरू सबैभन्दा लोकप्रिय छन् भनेर कसरी थाहा पाउन सकिन्छ? आफ्नो एनालिटिक्स जाँच गर्नुहोस् - तपाईं आफ्नो वेब विकास प्रक्रियाको भागको रूपमा विभिन्न एनालिटिक्स प्याकेजहरू स्थापना गर्न सक्नुहुन्छ, र तिनीहरूले विभिन्न लोकप्रिय ब्राउजरहरूद्वारा सबैभन्दा धेरै प्रयोग गरिएका ब्राउजरहरू के हुन् भनेर बताउँछन्। ## ब्राउजर एक्सटेन्सनहरू किन तपाईं ब्राउजर एक्सटेन्सन बनाउन चाहनुहुन्छ? यो ब्राउजरमा जोड्नको लागि उपयोगी कुरा हो जब तपाईं बारम्बार दोहोरिने कार्यहरूमा छिटो पहुँच चाहनुहुन्छ। उदाहरणका लागि, यदि तपाईंले आफूले अन्तरक्रिया गर्ने विभिन्न वेब पृष्ठहरूमा रंगहरू जाँच गर्न आवश्यक छ भने, तपाईंले रंग-पिकर ब्राउजर एक्सटेन्सन स्थापना गर्न सक्नुहुन्छ। यदि तपाईंलाई पासवर्ड सम्झन गाह्रो छ भने, तपाईं पासवर्ड-व्यवस्थापन ब्राउजर एक्सटेन्सन प्रयोग गर्न सक्नुहुन्छ। ब्राउजर एक्सटेन्सनहरू विकास गर्न रमाइलो हुन्छ। तिनीहरूले सीमित संख्याका कार्यहरू व्यवस्थित गर्छन् जुन तिनीहरूले राम्रोसँग प्रदर्शन गर्छन्। ✅ तपाईंको मनपर्ने ब्राउजर एक्सटेन्सनहरू के हुन्? तिनीहरूले कुन कार्यहरू प्रदर्शन गर्छन्? ### एक्सटेन्सनहरू स्थापना गर्दै तपाईंले निर्माण सुरु गर्नु अघि, ब्राउजर एक्सटेन्सन निर्माण र तैनातीको प्रक्रियालाई हेर्नुहोस्। प्रत्येक ब्राउजरले यो कार्यलाई कसरी व्यवस्थापन गर्छ भन्नेमा थोरै भिन्नता भए पनि, प्रक्रिया Chrome र Firefox मा Edge को यो उदाहरणसँग मिल्दोजुल्दो छ: ![Edge ब्राउजरको स्क्रिनशट जसले edge://extensions पृष्ठ र सेटिङ मेनु खुला देखाउँछ](../../../../translated_images/install-on-edge.d68781acaf0b3d3dada8b7507cde7a64bf74b7040d9818baaa9070668e819f90.ne.png) > नोट: सुनिश्चित गर्नुहोस् कि डेभलपर मोड टगल गरिएको छ र अन्य स्टोरहरूबाट एक्सटेन्सन अनुमति दिइएको छ। सारमा, प्रक्रिया यस्तो हुनेछ: - `npm run build` प्रयोग गरेर आफ्नो एक्सटेन्सन निर्माण गर्नुहोस् - ब्राउजरमा "सेटिङ्स र थप" बटन (माथि दायाँ रहेको `...` आइकन) प्रयोग गरेर एक्सटेन्सन प्यानमा नेभिगेट गर्नुहोस् - यदि यो नयाँ स्थापना हो भने, ताजा एक्सटेन्सन अपलोड गर्न `load unpacked` रोज्नुहोस् (हाम्रो केसमा यो `/dist` हो) - वा, पहिले नै स्थापना गरिएको एक्सटेन्सन पुनः लोड गर्न `reload` क्लिक गर्नुहोस् ✅ यी निर्देशनहरू तपाईंले आफैंले निर्माण गरेका एक्सटेन्सनहरूका लागि हुन्; प्रत्येक ब्राउजरसँग सम्बन्धित ब्राउजर एक्सटेन्सन स्टोरमा जारी गरिएका एक्सटेन्सनहरू स्थापना गर्न, तपाईंले ती [स्टोरहरू](https://microsoftedge.microsoft.com/addons/Microsoft-Edge-Extensions-Home) मा नेभिगेट गर्नुपर्छ र आफ्नो रोजाइको एक्सटेन्सन स्थापना गर्नुपर्छ। ### सुरु गर्नुहोस् तपाईं आफ्नो क्षेत्रको कार्बन फुटप्रिन्ट देखाउने ब्राउजर एक्सटेन्सन निर्माण गर्न जाँदै हुनुहुन्छ, जसले तपाईंको क्षेत्रको ऊर्जा प्रयोग र ऊर्जा स्रोत देखाउँछ। एक्सटेन्सनमा API कुञ्जी सङ्कलन गर्ने फारम हुनेछ ताकि तपाईं CO2 Signal को API पहुँच गर्न सक्नुहुन्छ। **तपाईंलाई चाहिन्छ:** - [एक API कुञ्जी](https://www.co2signal.com/); यस पृष्ठमा आफ्नो इमेल प्रविष्ट गर्नुहोस् र तपाईंलाई एउटा पठाइनेछ - [तपाईंको क्षेत्रको कोड](http://api.electricitymap.org/v3/zones) जुन [Electricity Map](https://www.electricitymap.org/map) सँग मेल खान्छ (उदाहरणका लागि, बोस्टनमा, म 'US-NEISO' प्रयोग गर्छु।) - [स्टार्टर कोड](../../../../5-browser-extension/start)। `start` फोल्डर डाउनलोड गर्नुहोस्; तपाईंले यस फोल्डरमा कोड पूरा गर्नुहुनेछ। - [NPM](https://www.npmjs.com) - NPM एक प्याकेज व्यवस्थापन उपकरण हो; यसलाई स्थानीय रूपमा स्थापना गर्नुहोस् र तपाईंको `package.json` फाइलमा सूचीबद्ध प्याकेजहरू तपाईंको वेब सम्पत्तिमा प्रयोगको लागि स्थापना गरिनेछ ✅ प्याकेज व्यवस्थापनको बारेमा थप जान्न यो [उत्कृष्ट Learn मोड्युल](https://docs.microsoft.com/learn/modules/create-nodejs-project-dependencies/?WT.mc_id=academic-77807-sagibbon) हेर्नुहोस्। कोडबेस हेर्न एक मिनेट लिनुहोस्: dist -|manifest.json (डिफल्टहरू यहाँ सेट गरिन्छ) -|index.html (फ्रन्ट-एन्ड HTML मार्कअप यहाँ) -|background.js (पृष्ठभूमि JS यहाँ) -|main.js (बन्डल गरिएको JS) src -|index.js (तपाईंको JS कोड यहाँ जान्छ) ✅ एक पटक तपाईंको API कुञ्जी र क्षेत्र कोड तयार भएपछि, तिनीहरूलाई भविष्यको प्रयोगको लागि नोटमा कहीं भण्डारण गर्नुहोस्। ### एक्सटेन्सनको HTML निर्माण गर्नुहोस् यस एक्सटेन्सनमा दुई दृश्यहरू छन्। एउटा API कुञ्जी र क्षेत्र कोड सङ्कलन गर्न: ![ब्राउजरमा खुला एक्सटेन्सनको स्क्रिनशट, क्षेत्र नाम र API कुञ्जीको लागि इनपुटहरू भएको फारम देखाउँदै।](../../../../translated_images/1.b6da8c1394b07491afeb6b2a8e5aca73ebd3cf478e27bcc9aeabb187e722648e.ne.png) र दोस्रो क्षेत्रको कार्बन प्रयोग देखाउन: ![US-NEISO क्षेत्रको लागि कार्बन प्रयोग र फोसिल इन्धन प्रतिशत देखाउँदै पूर्ण एक्सटेन्सनको स्क्रिनशट।](../../../../translated_images/2.1dae52ff0804224692cd648afbf2342955d7afe3b0101b617268130dfb427f55.ne.png) आउनुहोस् फारम निर्माण गरेर CSS द्वारा यसलाई स्टाइल गर्न सुरु गरौं। `/dist` फोल्डरमा, तपाईं फारम र परिणाम क्षेत्र निर्माण गर्नुहुनेछ। `index.html` फाइलमा, निर्दिष्ट फारम क्षेत्रलाई जनसंख्या गर्नुहोस्: ```HTML

New? Add your Information

``` यो फारम हो जहाँ तपाईंको सुरक्षित जानकारी इनपुट गरिनेछ र स्थानीय भण्डारणमा सुरक्षित गरिनेछ। अन्तिम फारम ट्याग अन्तर्गत, परिणाम क्षेत्र सिर्जना गर्नुहोस्; केही divs थप्नुहोस्: ```HTML
loading...

Region:

Carbon Usage:

Fossil Fuel Percentage:

``` यस बिन्दुमा, तपाईं निर्माण प्रयास गर्न सक्नुहुन्छ। सुनिश्चित गर्नुहोस् कि यस एक्सटेन्सनको प्याकेज निर्भरता स्थापना गरिएको छ: ``` npm install ``` यो कमाण्डले npm, Node Package Manager, प्रयोग गरेर तपाईंको एक्सटेन्सनको निर्माण प्रक्रियाको लागि webpack स्थापना गर्नेछ। तपाईं यस प्रक्रियाको आउटपुट `/dist/main.js` मा हेर्न सक्नुहुन्छ - तपाईंले देख्नुहुनेछ कि कोड बन्डल गरिएको छ। हालको लागि, एक्सटेन्सन निर्माण गर्नुपर्छ र यदि तपाईं यसलाई Edge मा एक्सटेन्सनको रूपमा तैनात गर्नुहुन्छ भने, तपाईंले एक फारम राम्रोसँग प्रदर्शन भएको देख्नुहुनेछ। बधाई छ, तपाईंले ब्राउजर एक्सटेन्सन निर्माण गर्ने दिशामा पहिलो कदम चालेको छ। आगामी पाठहरूमा, तपाईं यसलाई अझ कार्यात्मक र उपयोगी बनाउनुहुनेछ। --- ## 🚀 चुनौती ब्राउजर एक्सटेन्सन स्टोर हेर्नुहोस् र आफ्नो ब्राउजरमा एउटा स्थापना गर्नुहोस्। तपाईं यसको फाइलहरू रोचक तरिकामा जाँच गर्न सक्नुहुन्छ। तपाईंले के पत्ता लगाउनुहुन्छ? ## पोस्ट-लेक्चर क्विज [पोस्ट-लेक्चर क्विज](https://ff-quizzes.netlify.app/web/quiz/24) ## समीक्षा र आत्म अध्ययन यस पाठमा तपाईंले वेब ब्राउजरको इतिहासको बारेमा थोरै सिक्नुभयो; यस अवसरलाई वेबको आविष्कारकहरूले यसको प्रयोगलाई कसरी परिकल्पना गरे भन्ने बारेमा थप जान्न प्रयोग गर्नुहोस्। यसको इतिहासको बारेमा पढ्न केही उपयोगी साइटहरू समावेश छन्: [वेब ब्राउजरहरूको इतिहास](https://www.mozilla.org/firefox/browsers/browser-history/) [वेबको इतिहास](https://webfoundation.org/about/vision/history-of-the-web/) [टिम बर्नर्स-लीसँगको अन्तर्वार्ता](https://www.theguardian.com/technology/2019/mar/12/tim-berners-lee-on-30-years-of-the-web-if-we-dream-a-little-we-can-get-the-web-we-want) ## असाइनमेन्ट [तपाईंको एक्सटेन्सनलाई पुनः स्टाइल गर्नुहोस्](assignment.md) --- **अस्वीकरण**: यो दस्तावेज़ AI अनुवाद सेवा [Co-op Translator](https://github.com/Azure/co-op-translator) प्रयोग गरेर अनुवाद गरिएको हो। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।