# Browser Extensie Project Deel 1: Alles over Browsers ```mermaid journey title Your Browser Extension Development Journey section Foundation Understand browsers: 3: Student Learn extension types: 4: Student Setup development: 4: Student section Development Build interface: 4: Student Add functionality: 5: Student Handle data: 5: Student section Integration Test in browser: 5: Student Debug issues: 4: Student Polish experience: 5: Student ```  > Sketchnote door [Wassim Chegham](https://dev.to/wassimchegham/ever-wondered-what-happens-when-you-type-in-a-url-in-an-address-bar-in-a-browser-3dob) ## Pre-Les Quiz [Pre-les quiz](https://ff-quizzes.netlify.app/web/quiz/23) ### Introductie Browserextensies zijn mini-applicaties die je webbrowserervaring verbeteren. Net zoals Tim Berners-Lee's oorspronkelijke visie van een interactieve web, breiden extensies de mogelijkheden van de browser uit voorbij het simpel bekijken van documenten. Van wachtwoordmanagers die je accounts veilig houden tot kleurkiezers die ontwerpers helpen perfecte tinten te vinden, extensies lossen dagelijkse browse-uitdagingen op. Voordat we je eerste extensie gaan bouwen, is het belangrijk om te begrijpen hoe browsers werken. Net zoals Alexander Graham Bell geluidstransmissie moest begrijpen voordat hij de telefoon uitvond, zal kennis van browserfundamenten je helpen extensies te maken die naadloos integreren met bestaande browsersystemen. Aan het einde van deze les begrijp je de architectuur van browsers en ben je begonnen met het bouwen van je eerste extensie. ```mermaid mindmap root((Browser Architecture)) Core Components Rendering Engine JavaScript Engine Network Stack Storage APIs User Interface Address Bar Tab Management Bookmarks Extension Icons Extension System Manifest Files Content Scripts Background Pages Popup Windows Security Model Same-Origin Policy Permissions API Content Security Isolated Worlds Development Tools DevTools Integration Debug Console Performance Monitor Extension Inspector ``` ## Begrip van Web Browsers Een webbrowser is in wezen een geavanceerde documentvertaler. Wanneer je "google.com" in de adresbalk typt, voert de browser een complexe reeks operaties uit - het opvragen van inhoud van servers wereldwijd, en vervolgens het parseren en weergeven van die code in de interactieve webpagina's die je ziet. Dit proces weerspiegelt hoe de eerste webbrowser, WorldWideWeb, werd ontworpen door Tim Berners-Lee in 1990 om hyperlinked documenten toegankelijk te maken voor iedereen. ✅ **Een beetje geschiedenis**: De eerste browser heette 'WorldWideWeb' en werd in 1990 gemaakt door Sir Timothy Berners-Lee.  > Enkele vroegtijdige browsers, via [Karen McGrane](https://www.slideshare.net/KMcGrane/week-4-ixd-history-personal-computing) ### Hoe Browsers Webinhoud Verwerken Het proces tussen het invoeren van een URL en het zien van een webpagina omvat verschillende gecoördineerde stappen die binnen enkele seconden plaatsvinden: ```mermaid sequenceDiagram participant User participant Browser participant Extension participant DNS participant Server User->>Browser: Types URL and presses Enter Browser->>Extension: Trigger beforeRequest event Extension->>Extension: Check if URL needs modification Browser->>DNS: Looks up server IP address DNS->>Browser: Returns IP address Browser->>Server: Requests web page content Server->>Browser: Sends HTML, CSS, and JavaScript Browser->>Extension: Trigger beforeResponse event Extension->>Extension: Modify content if needed Browser->>User: Renders complete web page Extension->>User: Show extension UI updates ``` **Wat dit proces bereikt:** - **Vertaalt** de mens-leesbare URL naar een server IP-adres via DNS-lookup - **Legt** een veilige verbinding met de webserver via HTTP- of HTTPS-protocollen - **Vraagt** de specifieke webpagina-inhoud op van de server - **Ontvangt** HTML-markup, CSS-styling en JavaScript-code van de server - **Geeft** alle inhoud weer in de interactieve webpagina die je ziet ### Kernfuncties van Browsers Moderne browsers bieden talrijke functies die ontwikkelaars van extensies kunnen benutten: | Functie | Doel | Mogelijkheden voor extensies | |---------|---------|------------------------| | **Rendering Engine** | Geeft HTML, CSS en JavaScript weer | Inhoudsmodificatie, stylinginjectie | | **JavaScript Engine** | Voert JavaScript-code uit | Aangepaste scripts, API-interacties | | **Lokale Opslag** | Slaat gegevens lokaal op | Gebruikersvoorkeuren, gecachte gegevens | | **Netwerkstack** | Behandelt webverzoeken | Verzoekmonitoring, data-analyse | | **Beveiligingsmodel** | Beschermt gebruikers tegen schadelijke inhoud | Inhoudsfiltering, beveiligingsverbeteringen | **Begrip van deze functies helpt je:** - **Identificeren** waar je extensie de meeste waarde kan toevoegen - **Kiezen** van de juiste browser-API's voor de functionaliteit van je extensie - **Ontwerpen** van extensies die efficiënt werken met browsersystemen - **Zorgen** dat je extensie voldoet aan de beveiligingsrichtlijnen van de browser ### Overwegingen bij Cross-Browser Ontwikkeling Verschillende browsers implementeren standaarden met kleine variaties, vergelijkbaar met hoe verschillende programmeertalen hetzelfde algoritme anders kunnen verwerken. Chrome, Firefox en Safari hebben elk unieke kenmerken waarmee ontwikkelaars rekening moeten houden tijdens de ontwikkeling van extensies. > 💡 **Pro Tip**: Gebruik [caniuse.com](https://www.caniuse.com) om te controleren welke webtechnologieën worden ondersteund door verschillende browsers. Dit is van onschatbare waarde bij het plannen van de functies van je extensie! **Belangrijke overwegingen voor extensieontwikkeling:** - **Test** je extensie op Chrome, Firefox en Edge browsers - **Pas aan** aan verschillende browserextensie-API's en manifestformaten - **Behandel** variërende prestatiekenmerken en beperkingen - **Bied** alternatieven voor browser-specifieke functies die mogelijk niet beschikbaar zijn ✅ **Analytics Inzicht**: Je kunt bepalen welke browsers je gebruikers prefereren door analysepakketten te installeren in je webontwikkelingsprojecten. Deze gegevens helpen je prioriteiten te stellen welke browsers je eerst moet ondersteunen. ## Begrip van Browserextensies Browserextensies lossen veelvoorkomende browse-uitdagingen op door functionaliteit direct toe te voegen aan de browserinterface. In plaats van aparte applicaties of complexe workflows te vereisen, bieden extensies directe toegang tot tools en functies. Dit concept weerspiegelt hoe vroege computerpioniers zoals Douglas Engelbart zich voorstelden menselijke capaciteiten te vergroten met technologie - extensies vergroten de basisfunctionaliteit van je browser. ```mermaid quadrantChart title Browser Extension Categories x-axis Simple --> Complex y-axis Personal Use --> Professional Tools quadrant-1 Developer Tools quadrant-2 Enterprise Solutions quadrant-3 Personal Utilities quadrant-4 Productivity Apps Ad Blockers: [0.3, 0.2] Password Managers: [0.7, 0.3] Color Pickers: [0.4, 0.8] Code Formatters: [0.8, 0.9] Note Taking: [0.6, 0.5] Video Downloaders: [0.5, 0.2] Time Trackers: [0.7, 0.6] Screenshot Tools: [0.4, 0.4] ``` **Populaire extensiecategorieën en hun voordelen:** - **Productiviteitstools**: Takenbeheerders, notitie-apps en tijdtrackers die je helpen georganiseerd te blijven - **Beveiligingsverbeteringen**: Wachtwoordmanagers, adblockers en privacytools die je gegevens beschermen - **Ontwikkelaarstools**: Codeformatters, kleurkiezers en debugginghulpmiddelen die ontwikkeling stroomlijnen - **Inhoudsverbetering**: Leesmodi, videodownloaders en screenshottools die je webervaring verbeteren ✅ **Reflectievraag**: Wat zijn je favoriete browserextensies? Welke specifieke taken voeren ze uit en hoe verbeteren ze je browse-ervaring? ### 🔄 **Pedagogische Check-in** **Begrip van Browserarchitectuur**: Voordat je doorgaat naar extensieontwikkeling, zorg ervoor dat je: - ✅ Uitleg kunt geven over hoe browsers webverzoeken verwerken en inhoud weergeven - ✅ De belangrijkste componenten van browserarchitectuur kunt identificeren - ✅ Begrijpt hoe extensies integreren met browserfunctionaliteit - ✅ Het beveiligingsmodel herkent dat gebruikers beschermt **Snelle Zelftest**: Kun je het pad traceren van het typen van een URL tot het zien van een webpagina? 1. **DNS-lookup** zet URL om naar IP-adres 2. **HTTP-verzoek** haalt inhoud op van de server 3. **Parsing** verwerkt HTML, CSS en JavaScript 4. **Rendering** toont de uiteindelijke webpagina 5. **Extensies** kunnen inhoud op meerdere stappen aanpassen ## Extensies Installeren en Beheren Het begrijpen van het installatieproces van extensies helpt je de gebruikerservaring te anticiperen wanneer mensen je extensie installeren. Het installatieproces is gestandaardiseerd in moderne browsers, met kleine variaties in interfaceontwerp.  > **Belangrijk**: Zorg ervoor dat je ontwikkelaarsmodus inschakelt en extensies van andere winkels toestaat bij het testen van je eigen extensies. ### Installatieproces voor Ontwikkelingsextensies Wanneer je je eigen extensies ontwikkelt en test, volg je deze workflow: ```mermaid flowchart TD A[Write Code] --> B[Build Extension] B --> C{First Install?} C -->|Yes| D[Load Unpacked] C -->|No| E[Reload Extension] D --> F[Test Functionality] E --> F F --> G{Working Correctly?} G -->|No| H[Debug Issues] G -->|Yes| I[Ready for Users] H --> A I --> J[Publish to Store] style A fill:#e1f5fe style F fill:#e8f5e8 style I fill:#f3e5f5 style J fill:#fff3e0 ``` ```bash # Step 1: Build your extension npm run build ``` **Wat deze opdracht bereikt:** - **Compileert** je broncode naar browserklare bestanden - **Bundelt** JavaScript-modules in geoptimaliseerde pakketten - **Genereert** de uiteindelijke extensiebestanden in de `/dist` map - **Bereidt** je extensie voor op installatie en testen **Stap 2: Navigeer naar Browserextensies** 1. **Open** de extensiebeheerpagina van je browser 2. **Klik** op de knop "Instellingen en meer" (het `...`-icoon) rechtsboven 3. **Selecteer** "Extensies" in het dropdownmenu **Stap 3: Laad je Extensie** - **Voor nieuwe installaties**: Kies `load unpacked` en selecteer je `/dist` map - **Voor updates**: Klik op `reload` naast je al geïnstalleerde extensie - **Voor testen**: Schakel "Ontwikkelaarsmodus" in om toegang te krijgen tot extra debuggingfuncties ### Installatie van Productie-extensies > ✅ **Opmerking**: Deze ontwikkelingsinstructies zijn specifiek voor extensies die je zelf bouwt. Om gepubliceerde extensies te installeren, bezoek je de officiële browserextensiewinkels zoals de [Microsoft Edge Add-ons store](https://microsoftedge.microsoft.com/addons/Microsoft-Edge-Extensions-Home). **Begrip van het verschil:** - **Ontwikkelingsinstallaties** laten je niet-gepubliceerde extensies testen tijdens ontwikkeling - **Winkelinstallaties** bieden gecontroleerde, gepubliceerde extensies met automatische updates - **Sideloading** maakt installatie van extensies buiten officiële winkels mogelijk (vereist ontwikkelaarsmodus) ## Je Carbon Footprint Extensie Bouwen We gaan een browserextensie maken die de CO2-voetafdruk van het energieverbruik in jouw regio weergeeft. Dit project demonstreert essentiële concepten van extensieontwikkeling terwijl het een praktische tool voor milieubewustzijn creëert. Deze aanpak volgt het principe van "leren door te doen" dat effectief is gebleken sinds de onderwijstheorieën van John Dewey - technische vaardigheden combineren met zinvolle toepassingen in de echte wereld. ### Projectvereisten Voordat we beginnen met ontwikkelen, verzamelen we de benodigde middelen en afhankelijkheden: **Vereiste API-toegang:** - **[CO2 Signal API key](https://www.co2signal.com/)**: Voer je e-mailadres in om je gratis API-sleutel te ontvangen - **[Regiocode](http://api.electricitymap.org/v3/zones)**: Vind je regiocode met behulp van de [Electricity Map](https://www.electricitymap.org/map) (bijvoorbeeld, Boston gebruikt 'US-NEISO') **Ontwikkelingstools:** - **[Node.js en NPM](https://www.npmjs.com)**: Pakketbeheerder voor het installeren van projectafhankelijkheden - **[Starter code](../../../../5-browser-extension/start)**: Download de `start` map om te beginnen met ontwikkelen ✅ **Meer leren**: Verbeter je vaardigheden in pakketbeheer met deze [uitgebreide Learn module](https://docs.microsoft.com/learn/modules/create-nodejs-project-dependencies/?WT.mc_id=academic-77807-sagibbon) ### Begrip van de Projectstructuur Het begrijpen van de projectstructuur helpt om ontwikkelingswerk efficiënt te organiseren. Net zoals de Bibliotheek van Alexandrië was georganiseerd voor gemakkelijke kennisopslag, maakt een goed gestructureerde codebase ontwikkeling efficiënter: ``` project-root/ ├── dist/ # Built extension files │ ├── manifest.json # Extension configuration │ ├── index.html # User interface markup │ ├── background.js # Background script functionality │ └── main.js # Compiled JavaScript bundle ├── src/ # Source development files │ └── index.js # Your main JavaScript code ├── package.json # Project dependencies and scripts └── webpack.config.js # Build configuration ``` **Wat elk bestand doet:** - **`manifest.json`**: **Definieert** extensiemetadata, permissies en startpunten - **`index.html`**: **Creëert** de gebruikersinterface die verschijnt wanneer gebruikers op je extensie klikken - **`background.js`**: **Behandelt** achtergrondtaken en browsergebeurtenisluisteraars - **`main.js`**: **Bevat** de uiteindelijke gebundelde JavaScript na het bouwproces - **`src/index.js`**: **Bevat** je belangrijkste ontwikkelingscode die wordt gecompileerd naar `main.js` > 💡 **Organisatietip**: Bewaar je API-sleutel en regiocode in een veilige notitie voor gemakkelijke referentie tijdens ontwikkeling. Je hebt deze waarden nodig om de functionaliteit van je extensie te testen. ✅ **Beveiligingsopmerking**: Sla nooit API-sleutels of gevoelige inloggegevens op in je code repository. We laten je zien hoe je deze veilig kunt beheren in de volgende stappen. ## De Extensie Interface Maken Nu gaan we de componenten van de gebruikersinterface bouwen. De extensie gebruikt een tweeschermbenadering: een configuratiescherm voor de eerste setup en een resultatenpagina voor het weergeven van gegevens. Dit volgt het principe van progressieve onthulling dat sinds de vroege dagen van computerinterfaceontwerp wordt gebruikt - informatie en opties in een logische volgorde onthullen om gebruikers niet te overweldigen. ### Overzicht van Extensie Weergaven **Setup Weergave** - Configuratie voor eerste gebruik:  **Resultaten Weergave** - Weergave van CO2-voetafdrukgegevens:  ### Het Configuratieformulier Bouwen Het setupformulier verzamelt gebruikersconfiguratiegegevens tijdens het eerste gebruik. Zodra het is geconfigureerd, blijven deze gegevens opgeslagen in de browser voor toekomstige sessies. In het bestand `/dist/index.html`, voeg deze formulierstructuur toe: ```html
``` **Wat dit formulier doet:** - **Creëert** een semantische formulierstructuur met correcte labels en input-associaties - **Activeert** browser-autocomplete functionaliteit voor een verbeterde gebruikerservaring - **Vereist** dat beide velden worden ingevuld voordat het formulier wordt ingediend met behulp van het `required` attribuut - **Organiseert** invoervelden met beschrijvende klassenamen voor eenvoudige styling en JavaScript targeting - **Biedt** duidelijke instructies voor gebruikers die de extensie voor het eerst instellen ### De Resultatenweergave Bouwen Maak vervolgens het resultatengebied dat de CO2-voetafdrukgegevens zal tonen. Voeg deze HTML onder het formulier toe: ```htmlRegion:
Carbon Usage:
Fossil Fuel Percentage: