Domein E-mail & Office Website WordPress Hosting VPS
Ga terug
.com
$ 9.99 $ 26.99 /1ste jaar
.net
$ 9.99 $ 26.99 /1ste jaar
Ga terug
Inloggen
Configuratiescherm Webmail Website Builder Webshop File Manager WordPress

Wat is een IP-adres?

We gebruiken allemaal dagelijks het internet. Sterker nog, een website bezoeken of een vraag aan je slimme speakers stellen, is onderdeel van ons leven geworden. Maar wist je dat je alleen verbinding met een website of apparaat kunt maken via een IP-adres? In dit artikel lees je onder andere wat een IP-adres is en hoe het werkt.

vector

In het kort

Glossary

Een IP-adres is een unieke set nummers die een apparaat op een netwerk identificeert, zoals een computer of een smartphone. Het stelt apparaten in staat om met elkaar te communiceren en toegang te krijgen tot het internet.

Wat is een IP-adres?

IP-adres is de afkorting van Internet Protocol address. Het is een unieke cijferreeks die wordt gekoppeld aan elk apparaat dat verbonden is met het internet. Deze apparaten zijn onder andere computers, smartphones, routers, printers en servers. Via een IP-adres is het voor apparaten mogelijk om met elkaar te communiceren en informatie uit te wisselen via het internet.

Tip: Je kunt een IP-adres vergelijken met een huisadres. Een huisadres heb je nodig om post te kunnen versturen en te ontvangen.

Het belang van IP-adressen

IP-adressen zijn belangrijk in het dagelijks leven. Zonder deze adressen is het niet mogelijk om bijvoorbeeld een website te bezoeken, te netflixen, een document te printen of verbinding te maken met slimme speakers. Bij elke activiteit die jij via het internet doet, is dus een IP-adres betrokken.

Waaruit bestaat een IP-adres?

Een IP-adres bestaat uit een cijferreeks, uitgedrukt in 4 getallen met daartussen een punt. Elk getal heet een byte en ligt tussen de 0 en 255. Het IP-adresboek begint dus bij 0.0.0.0 en eindigt bij 255.255.255.255. Het laatste getal van het IP-adres verwijst naar het apparaat (de host) dat wordt gebruikt. De rest van de cijfers verwijzen naar het netwerk waarin het apparaat actief is. Dit systeem heet IPv4, Internet Protocol versie 4.

Van IPv4 naar IPv6

Naar verloop van tijd zijn IPv4-adressen schaars geworden. Dat is logisch, omdat het internet steeds groter wordt. Daarom werd IPv6 geïntroduceerd, Internet Protocol versie 6. Kortgezegd zijn er nu biljoenen IP-adressen beschikbaar voor het internet. Wil je meer weten over het verschil tussen IPv4 en IPv6? Lees dan ons artikel ‘Zo werkt IPv6’.

Hoe werkt een IP-adres?

De wereld van IP-adressen is erg technisch. Om je een beter beeld te geven van hoe een IP-adres werkt, vind je hieronder een voorbeeld van wat er achter de schermen gebeurt als je een website gaat bezoeken.

  1. Jij wilt jouw favoriete website bezoeken.
  2. Je geeft jouw webbrowser de opdracht om deze website te bezoeken.
  3. Je browser gaat op het internet op zoek naar de website door te zoeken naar het IP-adres van de server waarop deze website staat. Ondertussen neemt de browser het IP-adres van je computer mee, zodat de server met de computer kan communiceren.
  4. Je browser vraagt aan die server of hij alle bestanden van die website mag delen met het IP-adres van je computer.
  5. De server gaat in op het verzoek, waardoor je computer de benodigde bestanden ontvangt en de browser de website kan tonen.

Een IP-adres en het verband met een domeinnaam

In het bovenstaande voorbeeld typ je de domeinnaam van je favoriete website in je browser in. Wist je dat die domeinnaam eigenlijk het IP-adres is dat verwijst naar de server waarop die website draait? Een domeinnaam is een gebruiksvriendelijke vertaling van een IP-adres. Een domein als one.com is makkelijker te onthouden dan het IP-adres 195.47.247.9. Als je de IP-adressen van al jouw favoriete websites moet onthouden, is dat niet te doen. Daarom zijn domeinnamen het leven ingeblazen.

Weetje: Een computer kan geen domeinnamen lezen. Daarom worden ze omgezet naar een IP-adres. Dit wordt gedaan door het domeinnaamsysteem (DNS).

Soorten IP-adressen

Er bestaan verschillende soorten IP-adressen die je kunt onderverdelen in 3 groepen:

  1. Openbare vs. privé IP-adressen
  2. Dynamische vs. statische IP-adressen
  3. Gedeelde vs. specifieke IP-adressen

Openbare vs. privé IP-adressen

Wanneer je thuis verbinding maakt met het internet maak je gebruik van een openbaar IP-adres. Dit is het adres dat elk apparaat kan zien. Een openbaar IP-adres wordt door je internetserverprovider (ISP) toegewezen aan je router, dat kastje dat internet thuis mogelijk maakt. Andersom kunnen externe apparaten je openbare IP-adres vinden om zo verbinding met jouw netwerk te maken.

Een openbaar IP-adres kun je vergelijken met een brief die je ontvangt. De postbode (router) zorgt ervoor dat de brief van je moeder (extern apparaat) op je thuisadres (openbaar IP-adres) wordt afgeleverd.

Privé IP-adres

Een privé IP-adres wordt gekoppeld aan een apparaat binnen je thuisnetwerk. Hierdoor kan een router informatie vanaf het internet naar het juiste apparaat verzenden of vice versa, bijvoorbeeld naar je smartphone. Een privé IP-adres is niet zichtbaar.

In het vorige voorbeeld kreeg je dus een brief van je moeder (extern apparaat) via de postbode (router) op je huisadres (openbaar IP-adres). Jouw naam is in dit geval het privé IP-adres. Deze uitwisseling heet Network Address Translation (NAT).

Dynamische vs. statische IP-adressen

Openbare IP-adressen kun je verder onderverdelen in 2 soorten: dynamische en statische IP-adressen. Hieronder lees je er meer over.

Wat is een dynamisch IP-adres?

Een dynamisch IP-adres is een adres dat jouw ISP tijdelijk toewijst aan je apparaat dat verbinding heeft met het internet, bijvoorbeeld je smartphone. Dit adres kan in de loop der tijd veranderen, bijvoorbeeld als je opnieuw verbinding maakt met het internet of wanneer de ISP het adres wijzigt. ISP’s gebruiken het liefst dynamische IP-adressen, omdat ze doorgaans goedkoper zijn dan statische IP-adressen.

Wat is een statisch IP-adres?

Een statisch IP-adres is een vast adres voor een apparaat en verandert nooit. Voor bedrijven is een statisch IP-adres bijvoorbeeld handig als medewerkers vanuit huis toegang willen tot de e-mailserver waardoor ze hun e-mail kunnen checken. Of als je vanaf een vakantielocatie je beveiligingscamera’s wilt checken op ongewenste gasten. Als de e-mailserver of beveiligingscamera’s een dynamisch IP-adres zouden hebben, heb je naar verloop van tijd geen toegang meer. Het IP-adres moet je dan elke keer opnieuw instellen.

Shared vs. dedicated IP-adressen

Tot slot zijn er ook shared en dedicated IP-adressen. Deze adressen hebben betrekking tot websites en domeinnamen.

Shared IP-adres

Een shared IP-adres is een adres dat door meerdere websites wordt gebruikt. Website 1 is bijvoorbeeld bereikbaar via hetzelfde IP-adres als website 2. Deze situatie zie je vaak bij shared hosting, waarbij een server wordt gedeeld met meerdere mensen.

Voordelen

  • Betaalbaar doordat resources worden gedeeld
  • Eenvoudig in gebruik dankzij kant-en-klare software
  • Een goede reputatie dankzij andere goede websites op hetzelfde IP-adres

Nadelen

  • Minder resources beschikbaar als 1 website meer verkeer krijgt of data verbruikt
  • Gezamenlijk getroffen bij een DDoS-aanval
  • Slechte reputatie als het IP-adres op een blacklist komt te staan dankzij 1 website

Dedicated IP-adres

Een dedicated IP-adres is een adres dat door 1 server wordt gebruikt. Op deze server kunnen bijvoorbeeld jouw websites draaien. Deze situatie komt vaak voor bij een Virtual Private Server (VPS) of dedicated server.

Voordelen

  • Meer controle over de netwerk- en beveiligingsinstellingen
  • Eenvoudiger een SSL-certificaat verkrijgen
  • Eigen FTP-server hosten
  • Website bewerken via het IP-adres zonder dat je een domeinnaam hebt geregistreerd

Nadelen

  • Duurder
  • Zelf (technisch) onderhouden
Wat is mijn IP-adres? 
Wil je weten wat het IP-adres van je netwerk is? Typ simpelweg ‘what is my IP’ in Google in en je ziet direct wat je adres is. Of maak gebruik van de website Whatismyipaddress.com. Wil je weten wat het IP-adres van je website of andere website is? Die kun je checken op NsLookup.io.

Wat voor IP-adres heb ik nodig voor mijn website?

Ga je een website maken? Dan is het belangrijk dat je een statisch IP-adres gebruikt. Je website en e-mailadres die aan het IP-adres zijn gekoppeld kunnen dan blijvend worden gevonden door externe apparaten die met het internet zijn verbonden. Met een dynamisch IP-adres moet je dit telkens opnieuw instellen en dat is niet efficiënt. Als je jouw website gaat hosten, kun je ervan uitgaan dat je altijd een statisch IP-adres krijgt.

Kies je ervoor om je website te hosten op shared hosting? Dan maak je gebruik van een shared IP-adres. Wil je meer vrijheid en schaf je een VPS aan? Dan krijg je jouw eigen dedicated IP-adres.

Heb je nog geen hosting aangeschaft? Ga vandaag nog aan de slag bij one.com!

Bouw je website op razendsnelle webhosting

Bouw je website op razendsnelle webhosting

Maak van je online idee een succes. Host je site op snelle, veilige en betrouwbare servers.

Aan de slag
  • Gebruiksvriendelijk Control Panel
  • High-performance SSD servers
  • Gratis SSL certificaat
  • Gratis website maker
  • Dagelijkse back-up
  • 24/7 support
' html += '
' html += '' + ocKeys[locale].allPlans + '' html += '
' return html; } function ocGetLocale() { var localString = document.getElementsByTagName('html')[0].getAttribute("lang"); if (!localString) { return "en"; } if (localString.indexOf('-') === -1) { return localString; } return localString.split("-")[0] } function isInViewport(element) { var rect = element.getBoundingClientRect(); return ( rect.top >= 0 && rect.left >= 0 && rect.top <= (window.innerHeight || osShadowElement.documentElement.clientHeight) && rect.right <= (window.innerWidth || osShadowElement.documentElement.clientWidth) ); } function ocLogBuyClick(e) { if (!e.target.classList.contains("onecom_plans_cta_main")) { return; } var parent = e.target.parentNode.parentNode.parentNode.parentNode.parentNode; window.dataLayer.push({ event: "addToCart", ecommerce: { currencyCode: parent.getAttribute("data-currency"), add: { actionField: { list: document.getElementsByTagName('h1')[0].textContent }, products: [ { id: parent.getAttribute("data-title"), name: parent.getAttribute("data-title"), brand: "one.com", category: "pps", variant: parent.getAttribute("data-plan"), location: document.getElementsByTagName('h1')[0].textContent, price: parent.getAttribute("data-price"), quantity: 1 } ] } } }); } function ocLogTrackingInfo(e) { if ((e.getAttribute("data-marked") !== "1") || (!dataLayer)) { return; } e.removeAttribute("data-marked"); if (!e.getAttribute("data-title") || e.getAttribute("data-fresh") !== "1") { return; } console.info("push initiated") window.dataLayer.push({ id: e.getAttribute("data-title"), name: e.getAttribute("data-title"), brand: "one.com", category: "pps", variant: e.getAttribute("data-plan"), list: "/" + ocGetLocale() + "/", location: document.getElementsByTagName('h1')[0].textContent, price: e.getAttribute("data-price"), position: e.getAttribute("data-position") } ); e.setAttribute("data-fresh", "0"); } function ocSetImpression() { var plans = document.getElementsByClassName('oc-plan-container'); for (var i = 0; i < plans.length; i++) { if (isInViewport(plans[i])) { ocLogTrackingInfo(plans[i]); } } } function ocProductImpression(e) { var plans = document.getElementsByClassName('oc-plan-container'); for (var i = 0; i < plans.length; i++) { if (isInViewport(plans[i])) { plans[i].setAttribute("data-marked", "1"); ocTimeout = setTimeout(ocSetImpression, 2000) } } } /* var headingTag = window.location.hash.substr(1); if(headingTag.length > 0){ console.log(headingTag); osShadowElement.querySelector('#'+headingTag).scrollIntoView(); } */ //frontpage function scrollSmooth() { var elmntToView = osShadowElement.querySelector("#oc-plansandprices"); elmntToView.scrollIntoView({ behavior: "smooth", block: "start", inline: "nearest" }); } const rightBtn = osShadowElement.querySelector('#right-button'); const leftBtn = osShadowElement.querySelector('#left-button'); if (rightBtn && leftBtn) { rightBtn.addEventListener("click", function (event) { const conent = osShadowElement.querySelector('#content'); conent.scrollLeft += 100; event.preventDefault(); let activeElement = osShadowElement.querySelector(".banner-thumb.active"); if (osShadowElement.querySelector(".banner-menu li:last-child").classList.contains('active')) { osShadowElement.querySelector(".banner-menu li:first-child").click(); } else { if (activeElement.nextElementSibling) { activeElement.nextElementSibling.click(); } } }); leftBtn.addEventListener("click", function (event) { const conent = osShadowElement.querySelector('#content'); conent.scrollLeft -= 100; event.preventDefault(); let activeElement = osShadowElement.querySelector(".banner-thumb.active"); if (osShadowElement.querySelector(".banner-menu li:first-child").classList.contains('active')) { osShadowElement.querySelector(".banner-menu li:last-child").click(); } else { if (activeElement.previousElementSibling) { activeElement.previousElementSibling.click(); } } }); } function nextSlide(thumbClass) { if (thumbClass.length > 0) { var elements = osShadowElement.querySelectorAll(".banner-section"); for (var i = 0, len = elements.length; i < len; i++) { elements[i].style.display = "none"; } var elements = osShadowElement.querySelectorAll(".banner-thumb"); for (var i = 0, len = elements.length; i < len; i++) { elements[i].classList.remove("active"); } var elmntToView = osShadowElement.querySelector('.banner-section-' + thumbClass); elmntToView.scrollIntoView({ behavior: "smooth", block: "start", inline: "nearest" }); var menuClicked = osShadowElement.querySelector('.banner-thumb-' + thumbClass); menuClicked.classList.add("active"); menuClicked.scrollIntoView(); osShadowElement.querySelector('.banner-section-' + thumbClass).style.display = "block"; } } const accordionTitlesSuccess = osShadowElement.querySelectorAll(".success-steps-col"); accordionTitlesSuccess.forEach((accordionTitle) => { accordionTitle.addEventListener("click", () => { if (accordionTitle.classList.contains("active")) { accordionTitle.classList.remove("active"); } else { const accordionTitlesWithIsOpen = document.querySelectorAll(".success-steps-col"); accordionTitlesWithIsOpen.forEach((accordionTitleWithIsOpen) => { accordionTitleWithIsOpen.classList.remove("active"); }); accordionTitle.classList.add("active"); } }); }); const accordionTitlesFaq = osShadowElement.querySelectorAll(".faq-col"); accordionTitlesFaq.forEach((accordionTitle) => { accordionTitle.addEventListener("click", () => { if (accordionTitle.classList.contains("active")) { accordionTitle.classList.remove("active"); } else { const accordionTitlesWithIsOpen = document.querySelectorAll(".faq-col"); accordionTitlesWithIsOpen.forEach((accordionTitleWithIsOpen) => { accordionTitleWithIsOpen.classList.remove("active"); }); accordionTitle.classList.add("active"); } }); }); (function () { slide('right'); })(); /***script to call APIs starts here**/ function checkStatus(response) { if (response.status >= 200 && response.status < 300) { return Promise.resolve(response); } else { return Promise.reject(new Error(response.statusText)); } } function parseJson(response) { return response.json(); } function niceRounding(stringDigit) { var lastDigit = stringDigit.at(-1); if (lastDigit == 8) { stringDigit = stringDigit.replace(/.$/, "9"); } return stringDigit; } /***script to call APIs ends here**/ /**Glosssary page***/ function scrollSmoothGlossary(alphabet) { var alphaList = osShadowElement.querySelectorAll(".alphabet-list"); for (let i = 0; i < alphaList.length; i++) { alphaList[i].classList.remove("active"); } var activeAlpha = osShadowElement.querySelector(".alpha-" + alphabet); activeAlpha.classList.add("active"); var elmntToView = osShadowElement.querySelector("#div-" + alphabet); //elmntToView.scrollTop = elmntToView.scrollHeight; elmntToView.scrollIntoView({ behavior: "smooth" }); //elmntToView.scrollTop(elmntToView.scrollHeight); } /**searching**/ const $search = osShadowElement.getElementById('search-glossary'); if ($search) { $search.addEventListener('input', (event) => { const searchText = event.target.value; const regex = new RegExp(searchText, 'gi'); const noSearchDiv = osShadowElement.querySelector(".no-glossary-search-found"); const itemList = osShadowElement.querySelectorAll(".oc-glossary-item-articles"); //const articleList = osShadowElement.querySelectorAll(".item-article"); var mainCount = 0; for (let j = 0; j < itemList.length; j++) { var articleList = itemList[j].querySelectorAll(".item-article"); var countDisplayBlock = 0; for (let i = 0; i < articleList.length; i++) { var h3 = articleList[i].getElementsByTagName("a")[0]; var text = h3.innerHTML; text = text.replace(/(|<\/mark>)/gim, ''); const newText = text.replace(regex, '$&'); h3.innerHTML = newText; if (text !== newText) { articleList[i].style.display = "flex"; countDisplayBlock++; } else { articleList[i].style.display = "none"; } } if (countDisplayBlock === 0) { itemList[j].parentNode.parentNode.style.display = "none"; } else { itemList[j].parentNode.parentNode.style.display = "flex"; mainCount++; } } if (mainCount === 0) { noSearchDiv.classList.remove("hidden"); } else { noSearchDiv.classList.add("hidden"); } }); } var select = osShadowElement.getElementById('alphabet-mobile-select'); if (select) { select.onchange = function () { var alphabet = this.options[this.selectedIndex].value; this.options[this.selectedIndex].classList.add('active'); scrollSmoothGlossary(alphabet); //var elmntToView = osShadowElement.querySelector("#" + alphabet); //elmntToView.scrollIntoView({behavior: "smooth", block: "start", inline: "nearest"}); }; } var glossaryHeader = osShadowElement.getElementById("glossary-header"); var glossaryStickyHeader = osShadowElement.getElementById( "glossary-header-sticky" ); // Get the offset position of the navbar if (glossaryHeader) { var sticky = glossaryHeader.offsetTop; } var glossarySearch = osShadowElement.querySelector(".oc-glossary-search"); // Add the sticky class to the navbar when you reach its scroll position. Remove "sticky" when you leave the scroll position function stickyAlphabets() { if (window.pageYOffset > sticky) { glossaryHeader.classList.add("hidden"); glossaryStickyHeader.classList.remove("hidden"); glossaryStickyHeader.style.zIndex = "99999"; glossarySearch.classList.add("hidden"); } else { glossaryHeader.classList.remove("hidden"); glossaryStickyHeader.classList.add("hidden"); glossarySearch.classList.remove("hidden"); } } /** HIGHLIGHT ALPHABET NAVIGATION LINKS WHILE SCROLLING */ // cache the navigation list-items containing links var navigationLinks = osShadowElement.querySelectorAll('#glossary-header-sticky > .glossary-header-alphabets > ul > li'); // cache the alphabet sections var sections = osShadowElement.querySelectorAll('.oc-glossary-item > div > span.item-head'); // map each target section ID to the corresponding navigation list-items var sectionIdToNavigationLink = {}; for (var i = 0; i < sections.length; i++) { var id = sections[i].id; sectionIdToNavigationLink[id] = osShadowElement.querySelectorAll('#glossary-header-sticky > .glossary-header-alphabets > ul > li.alpha-' + id); } function getOffset(el) { var _x = 0; var _y = 0; while (el && !isNaN(el.offsetLeft) && !isNaN(el.offsetTop)) { _x += el.offsetLeft - el.scrollLeft; _y += el.offsetTop - el.scrollTop; el = el.offsetParent; } return { top: _y, left: _x }; } function highlightNavigation() { // get the current vertical position of the scroll bar var scrollPosition = window.pageYOffset || document.documentElement.scrollTop; // iterate the sections for (var i = sections.length - 1; i >= 0; i--) { var currentSection = sections[i]; // get the position of the section var sectionTop = getOffset(currentSection).top; // if the user has scrolled over the top of the section if (scrollPosition >= sectionTop - 250) { // get the section id var id = currentSection.id; // get the corresponding navigation link var navigationLink = sectionIdToNavigationLink[id]; // if the link is not active if (typeof navigationLink[0] !== 'undefined') { if (!navigationLink[0].classList.contains('active')) { // remove .active class from all the links for (i = 0; i < navigationLinks.length; i++) { navigationLinks[i].className = navigationLinks[i].className.replace(/ active/, ''); } // add .active class to the current link navigationLink[0].className += (' active'); } } else { // remove .active class from all the links for (i = 0; i < navigationLinks.length; i++) { navigationLinks[i].className = navigationLinks[i].className.replace(/ active/, ''); } } // we have found our section, so we return false to exit the each loop return false; } } } if (glossaryHeader) { window.addEventListener('scroll', highlightNavigation); } /** Glossary page ends here**/ /** NL frontpage modification - version 2.0 **/ // Get the HTML element you need. const imageOverlay = osShadowElement.getElementById('testimonial-video-section-block-image-overlay'); const playButton = osShadowElement.getElementById('testimonial-video-section-block-play'); if (playButton) { var vidId = playButton.getAttribute("data"); // Add the event listener for the play button. playButton.addEventListener('click', play) } // The function that is called when the button is clicked. function play(e) { e.preventDefault(); let iframe_tag = osShadowElement.getElementById('ytplayer'); iframe_tag.setAttribute('src', 'https://www.youtube.com/embed/' + vidId + '?autoplay=1&enablejsapi=1&origin=http%3A%2F%2Flocalhost&widgetid=1'); imageOverlay.style.opacity = '0'; playButton.style.opacity = '0'; window.setTimeout(function () { playButton.style.display = 'none'; imageOverlay.style.display = 'none'; }, 800); // timed to match animation-duration } // Glossary page navigationbar issue fix Start let elemWebTopMenu = document.querySelector(".WebTop-Nav"); let elemWebTopSearch = document.querySelector(".MegaMenuAndSearchWrapper"); let elem = document.querySelector("#glossary-header-sticky"); if (elem && ( elemWebTopMenu || elemWebTopSearch ) ) { let rect = elem.getBoundingClientRect(); let elemTop = rect.top; let elemBottom = rect.bottom; let rectWebTop = elemWebTopMenu.getBoundingClientRect(); let elemTopWebTop = rectWebTop.top; let elemBottomWebTop = rectWebTop.bottom; let rectWebTopSearch = elemWebTopSearch.getBoundingClientRect(); let elemTopWebTopSearch = rectWebTopSearch.top; let elemBottomWebTopSearch = rectWebTopSearch.bottom; if ( ( elemBottomWebTopSearch >= elemTop ) || ( elemBottomWebTop >= elemTop ) ) { elem.style.zIndex = 200; } else { elem.style.zIndex = 0; } document.addEventListener('scroll', function() { let rect = elem.getBoundingClientRect(); let elemTop = rect.top; let elemBottom = rect.bottom; let rectWebTop = elemWebTopMenu.getBoundingClientRect(); let elemTopWebTop = rectWebTop.top; let elemBottomWebTop = rectWebTop.bottom; let rectWebTopSearch = elemWebTopSearch.getBoundingClientRect(); let elemTopWebTopSearch = rectWebTopSearch.top; let elemBottomWebTopSearch = rectWebTopSearch.bottom; if ( ( elemBottomWebTopSearch >= elemTop ) || ( elemBottomWebTop >= elemTop ) ) { elem.style.zIndex = 200; } else { elem.style.zIndex = 0; } }); } let glossaryNav = document.querySelector("#glossary-header-sticky"); let topSearchBarGloss = document.querySelector(".MegaMenuAndSearchWrapper"); let navSpacer = document.querySelector(".NavSpacer"); if ( glossaryNav && topSearchBarGloss) { topSearchBarGloss.style.position = 'static'; navSpacer.style.display = 'none'; } // Glossary page navigationbar issue fix End /******* Custom YouTube video embed js start *******/ let yt_thumb_wraps = document.querySelectorAll('.yt-video-wrapper.yt-play-icon'); if (yt_thumb_wraps) { yt_thumb_wraps.forEach(yt_thumb_wrap => { yt_thumb_wrap.addEventListener("click", function(event) { event.preventDefault(); let vid = event.target.dataset.vid; let yt_thumb = event.target; let vtitle = yt_thumb.getAttribute("title"); if(!vid){ yt_thumb = yt_thumb.querySelector('.yt-thumb-image'); vid = yt_thumb.dataset.vid; vtitle = yt_thumb.getAttribute("title"); } if(vid && yt_thumb){ let ytvideo = ''; let yt_thumb_wrap = yt_thumb.closest('.yt-video-wrapper.yt-play-icon'); yt_thumb_wrap.innerHTML = ytvideo; yt_thumb_wrap.classList.remove("yt-play-icon"); } }); }); } /******* Custom YouTube video embed js end *******/