werken met DOM
Aanpassingen maken in de DOM-tree bestaat uit twee stappen:
Het selecteren van de node die je wilt aanpassen.
Het gebruiken van eigenschappen of methoden om een wijziging door te voeren.
querySelector()
Een node selecteer je met de methode document.querySelector(). Binnen querySelector() geef je een string mee die werkt als een CSS-selector.
Bijvoorbeeld: .test selecteert het eerste element met de class test.
let elExample = document.querySelector('#example');
elExample.textContent = "Nieuwe tekst";Meer informatie over document.querySelector vind je op MDN web docs
querySelectorAll()
Met document.querySelectorAll() kun je meerdere elementen tegelijk selecteren die overeenkomen met de opgegeven CSS-selector. Deze methode geeft een NodeList terug, een array-achtig object waar je op verschillende manieren doorheen kunt loopen, zoals met forEach() of via indexering.
let alleItems = document.querySelectorAll('li');
alleItems.forEach(item => {
item.style.color = 'blue';
});Je kunt ook specifieke elementen selecteren via indexering:
let derdeItem = document.querySelectorAll('li')[2];
derdeItem.textContent = "Aangepast item";Meer informatie over document.querySelectorAll vind je op MDN web docs
Parent
Een parent is het element dat zich direct boven het geselecteerde element bevindt in de DOM-structuur. In afbeelding 1 zie je bijvoorbeeld één div-element; het parent-element daarvan is de body.
Je kunt het parent-element van een geselecteerd element opvragen met:
let elParent = document.querySelector("section").parentElement;Children
Je kunt ook in omgekeerde richting werken, van een parent naar child-elementen.
let elChildren = document.querySelector("section").children;Een element kan meerdere child-elementen bevatten. Een voorbeeld waarbij we het vierde element uit een lijst vanuit de parent verwijderen.
let removeEl = document.querySelectorAll("li")[3]; // The element to remove
let containerEl = removeEl.parentNode; // The parent element
containerEl.removeChild(removeEl); // Removing the elementLast updated
