[AGGIORNAMENTO 01 Agosto 2022]
Attenzione: in seguito al provvedimento del Garante Privacy italiano che ha dichiarato illecita l’implementazione di Google Universal Analytics (GA3) su un sito web, è necessario eliminare il prima possibile la proprietà di GA3 dai propri progetti web e passare subito a GA4.
Se non hai dimestichezza con GA4 e desideri imparare a padroneggiare nel modo corretto questo strumento, nel mio libro su GA4 “Google Analytics 4 per chi inizia” ti guido passo passo per imparare a utilizzarlo in maniera semplice e pratica.
Per tracciare in GA4 la visualizzazione dei video Youtube inseriti sul tuo sito web ti basta configurare nel modo corretto gli eventi Enhanced Measurement (eventi di misurazione avanzata).
–
Questa guida risale prima che Google Tag Manager creasse l’attivatore e le variabili integrate per il tracciamento di video su Youtube.
Inoltre, se hai disattivato i cookie di YouTube come ti ho spiegato nel mio #barbatrucco, per tracciare i video col nocookie ora dovrai seguire quest’altra guida.
Nonostante questo aggiornamento ho voluto mantenere questo articolo e non cancellarlo, perché in fondo è pur sempre una soluzione funzionante 😉
Pronti allora!
Hai inserito dei video di YouTube nel tuo sito? Ti interesserebbe avere informazioni sull’interazione degli utenti con questi video?
Grazie a questa guida potrai capire come fare, con Google Tag Manager, ad avere informazioni sulla visualizzazione dei video da parte degli utenti del tuo sito, capire quindi se hanno cliccato “play”, “pausa” o se hanno visionato il video, ad esempio, fino a metà, fino al 75% oppure interamente.
Per fare questo utilizzeremo la JavaScript API di YouTube, che consente di controllare tramite JavaScript i video incorporati di YouTube per avere informazioni sulla loro riproduzione.
Ad esempio:
<iframe width="560" height="315" src="https://www.youtube.com/embed/MR5Uq1AMyk4" frameborder="0" allowfullscreen></iframe>
Bene, in questo modo sarà possibile inviare i dati relativi alla visualizzazione del video a Google Tag Manager e quindi, successivamente, a Google Analytics.
Per prima cosa crea l’Attivatore. Entra quindi nel tuo account di Google Tag Manager, poi fai così:
Crea quindi un nuovo Tag.
<script type="text/javascript"> for (var e = document.getElementsByTagName("iframe"), x = e.length; x--;) if (/youtube.com\/embed/.test(e[x].src)) if(e[x].src.indexOf('enablejsapi=') === -1) e[x].src += (e[x].src.indexOf('?') ===-1 ? '?':'&') + 'enablejsapi=1'; var gtmYTListeners = []; function onYouTubeIframeAPIReady() { for (var e = document.getElementsByTagName("iframe"), x = e.length; x--;) { if (/youtube.com\/embed/.test(e[x].src)) { gtmYTListeners.push(new YT.Player(e[x], { events: { onStateChange: onPlayerStateChange, onError: onPlayerError } })); YT.gtmLastAction = "p"; } } } function onPlayerStateChange(e) { e["data"] == YT.PlayerState.PLAYING && setTimeout(onPlayerPercent, 1000, e["target"]); var video_data = e.target["getVideoData"](), label = video_data.video_id+':'+video_data.title; if (e["data"] == YT.PlayerState.PLAYING && YT.gtmLastAction == "p") { dataLayer.push({ event: "youtube", action: "play", label: label }); YT.gtmLastAction = ""; } if (e["data"] == YT.PlayerState.PAUSED) { dataLayer.push({ event: "youtube", action: "pause", label: label }); YT.gtmLastAction = "p"; } } function onPlayerError(e) { dataLayer.push({ event: "error", action: "GTM", label: "youtube:" + e }) } function onPlayerPercent(e) { if (e["getPlayerState"]() == YT.PlayerState.PLAYING) { var t = e["getDuration"]() - e["getCurrentTime"]() <= 1.5 ? 1 : (Math.floor(e["getCurrentTime"]() / e["getDuration"]() * 4) / 4).toFixed(2); if (!e["lastP"] || t > e["lastP"]) { var video_data = e["getVideoData"](), label = video_data.video_id+':'+video_data.title; e["lastP"] = t; dataLayer.push({ event: "youtube", action: t * 100 + "%", label: label }) } e["lastP"] != 1 && setTimeout(onPlayerPercent, 1000, e); } } window.onbeforeunload = function (e) { var e = e || window.event; if(e) e.returnValue = 'na'; return 'na'; }; window.onbeforeunload = trackYTUnload; function trackYTUnload() { for (var i = 0; i < gtmYTplayers.length; i++) if (gtmYTlisteners[i].getPlayerState() === 1) { var video_data = gtmYTlisteners[i]['getVideoData'](), label = video_data.video_id+':'+video_data.title; dataLayer.push({ event: 'youtube', action: 'exit', label: label }); } } var j = document.createElement("script"), f = document.getElementsByTagName("script")[0]; j.src = "//www.youtube.com/iframe_api"; j.async = true; f.parentNode.insertBefore(j, f); </script>
Se hai problemi prova con la libreria minificata che trovi questo link.
Attiva ora la modalità Visualizzazione in Anteprima di Google Tag Manager, vai nella pagina che contiene il video ed avvialo.
Nel box in basso vedrai comparire diversi eventi. Dalla scheda Data Layer puoi vedere che l’elemento action può avere il valore: “play“, “pause“, “0%“, “25%“, “50%“, “75%“, “100%” (rispettivamente quando il video inizia ad essere riprodotto, viene messo in pausa, arriva al 25%, al 50%, al 75% e viene completato) e label che corrisponde al codice e al titolo del video riprodotto.
Per passare i dati degli elementi action e label a Google Analytics dovrai creare delle Variabili.
Allo stesso modo, crea la Variabile “Label”.
L’ultimo step è creare un Tag per passare queste Variabili appena create a Google Analytics.
Infine, nomina anche il Tag in questo modo “GA – Event – Video Youtube” e salvalo.
Ora hai fatto tutto il necessario per trasferire queste informazioni a Google Analytics.
Potrai quindi visualizzare tra gli eventi di Google Analytics (Comportamento > Eventi) tutti gli eventi relativi alla visualizzazione dei video da parte degli utenti. Puoi notare quindi se gli utenti tendono a vedere interamente i tuoi video, oppure arrivano la maggior parte delle volte al 25%, ad esempio.
Nel video tutorial ho utilizzato l’ultima versione degli script, che ha dei nomi leggermente diversi rispetto alla guida scritta.
Gli script e le informazioni su come implementare questa funzionalità di tracciamento sono stati presi da un post di Bounteous (ex Lunametrics): https://www.bounteous.com/insights/2015/05/11/youtube-tracking-google-analytics-google-tag-manager/
Prova ad implementare questa funzionalità, se dovessi riscontrare problemi, non esitare a scrivermi!
Buon Tag!
Quando qualche anno fa Google Tag Manager lanciò l’Attivatore Visibilità di un Elemento ricordo ancora…
Non credo sia necessario specificare che oggi la maggior parte delle visite e una bella…
Se sei un digital marketer o un digital analyst probabilmente saprai quanto oggi sia importante…
In occasione dell’evento “ECOMMERCE FOOD CONFERENCE” di Bologna, Tag Manager Italia ha condotto una ricerca…
Google Analytics 4 è uno strumento straordinario per raccogliere e analizzare i dati sul comportamento…
Se segui le guide e i webinar di Tag Manager Italia da un po’, probabilmente…
View Comments
Ciao Matteo, ti segue da molto e grazie ai tuoi tutorial sono riuscito a fare praticamente tutto quello di cui avevo bisogno. Oggi avrei bisogno di registrare tramite GA i puntatori che vengono visualizzati dentro la mappa che viene visualizzata dentro una pagina web. Ti faccio un esempio pratico, per questa pagina:
https://www.touripp.it/tour/italia-via-francigena-bike-trail/
vorrei avere un evento "Mappa" con nei dettagli le città che hanno il puntatore di google maps quindi:
Viterbo - Sutri - Campagnano di Roma - Roma
Riesci a darmi qualche suggerimento?
Grazie mille in anticipo e buon lavoro!
Ciao Nicola, purtroppo essendo dentro un iframe e non potendo inserire GTM dentro (perché sei su Maps) non potrai mai sapere cosa viene cliccato. Se lato programmazione riesci a restituire un push quando l'utente clicca uno dei punti allora puoi tracciarlo. Se hai bisogno posso farti una consulenza (è troppo lunga via commento da spiegare). Se sei interessato manda pure una richiesta qui: https://dev.tagmanageritalia.it/richiedi-consulenza/
Ancora complimenti per il lavoro che stai facendo con Tag Manager
Volevo chiederti se ti è mai capitato di tracciare tutto quello che succede dentro ad una mappa di Google Maps all'interno del sito. In particolare vorrei creare un evento ogni volta che viene utilizzato il tasto +/- , ogni volta che viene utilizzato "omino giallo", ogni volta che viene fatto click all'interno della mappa e/o se viene fatto scroll up/down
Grazie come sempre per il materiale pubblicato e per le risposte alle mie domande
Tag
Maps script
HTML personalizzato (solo nelle pagine interessate)
Tag
Maps
Google Analytics - Universal Analytics
iFrameEntered
Con anteprima vedo che si attiva correttamente il primo Tag
ma se provo ad utilizzare la mappa (zoom in/out, click su vari punti, ecc)
non si attiva il tag per aggiungere evento in GA
Sicuramente sbaglio in passaggio ?!
Ciao Fabio, quello che puoi catturare è che l'utente entri con il mouse nell'iframe. Quello che fa dentro (anche niente) non lo potrai mai sapere. :)
Si la mappa è presente in molte pagine e si apre in automatico.
"Quello che puoi fare è capire se interagiscono con l’iframe ma non con il contenuto" si vorrei solo sapere se interagiscono con la mappa, come potrei fare?
Yep. Ti basta fare un HTML personalizzato con questo codice:
[script]
var frames = document.getElementsByTagName("iframe");
for (var i = 0; i < frames.length; i++) {
if (frames[i].src.startsWith("https://www.google.com/maps/embed?")) {
frames[i].addEventListener("mouseenter", function(e) {
dataLayer.push({
'event': 'iFrameEntered'
});
});
}
}
[/script]
A questo punto ti basta creare un evento personalizzato iFrameEntered.
Ovviamente metti i simboli maggiore e minore invece di [ e ] su script
:)
Grazie Matteo, in realtà non ho bisogno di vedere e/o registrare cosa ci sia dentro ma solo capire a livello statistico quanti utenti "usano la mappa" cliccandoci sopra. non si riesce a fare nemmeno questo?
La mappa è sempre aperta o si apre attraverso un pulsante?
Diciamo che GTM vede come se ci fosse un buco nero dove c'è l'iframe. L'unico modo per tracciarlo è avere il GTM dentro l'iframe.
Quello che puoi fare è capire se interagiscono con l'iframe ma non con il contenuto.
Ciao Fabio e grazie per i complimenti :)
La mappa di Maps è embeddata quindi è di per sè un iframe dove non hai possibilità di vedere cosa c'è dentro a meno che tu non riesca a convincere Google a installare su ogni Google Maps il tuo GTM :)
In sintesi non si può fare. Quello che potresti fare è calcolare dove fisicamente sono i pulsanti sullo schermo (ma varierà a seconda della grandezza e risoluzione dello schermo) e presupporre che ci sia un click in quel punto esatto dello schermo e associarlo ai pulsanti.
A presto!
Ciao Matteo,
ho seguito le tue istruzioni per il monitoraggio video ma ho un problema: le azioni vengono tracciate su Analytics soltanto quando guardo il video dal mio pc, mentre se viene guardato da altri utenti il monitoraggio non avviene. Hai idea di cosa potrei aver sbagliato?
Grazie
Ciao Matteo,
sì. Ho provato sia inserendo direttamente l'ID monitoraggio, sia creando e inserendo la costante di GA.
Riesci a mostrarmi uno screen della configurazione del tag e dell'attivatore?
Ciao Matteo,
grazie per la risposta, ma il problema purtroppo continua anche con l'attivatore nativo.
Non ho inserito la variabile GA nel tag evento (step 3), ho solo selezionato "Abilita l’override delle impostazioni". Può essere questo il problema?
Grazie
Ciao Fabio,
hai inserito la costante di Google Analytics nella sezione "ID di monitoraggio"?
Ciao Fabio, usa l'attivatore nativo di GTM: https://dev.tagmanageritalia.it/guida-base-come-tracciare-video-youtube-google-tag-manager/
Fammi sapere :)
Ciao Matteo gran bella notizia,
esiste il modo che tu sappia di passare i dati non a Google Analytics ma al CRM? (infusionsoft, Active Campaign)
Ciao Francesco,
sì certo, puoi farlo con le API ;)
Ciao Matteo,
Complimenti per le guide, sono molto semplici ed efficaci! Sto avendo problemi ad implementare questo script, nonostante abbia seguito la guida e preso il codice per "VIMEO" dal link che hai postato su, continua a non funzionare (mentre se uso il codice di youtube funziona alla grande), dici che per il tracking dei video vimeo, ci sia bisogno di eseguire dei passaggi differenti?
Grazie
Ciao Gian,
per Vimeo c'è questo script: https://github.com/sanderheilbron/vimeo.ga.js (non l'ho provato) tienimi aggiornato :)
Buongiorno,
ma se il video non fosse di youtube, bensì avesse una fonte differente?
Grazie
Ciao Giorgia, bisognerebbe modificare lo script (che ha creato lunametrics). Per VIMEO ad esempio c'è questo https://github.com/sanderheilbron/vimeo.ga.js (non l'ho provato).
A presto!
Grazie per la risposta!
Proverò a fare come consigli.
Ciao,
ho cominciato ad usare TagManager da pochissimo tempo e sto imparando tanto grazie alle vostre guide.
Vorrei sapere se è possibile tracciare in modo separato le singole visualizzazioni a diversi video presenti in un'unica pagina.
Grazie mille!
Niente da fare.
Non riesco ad usare correttamente la JavaScript API dei singoli video e impostare correttamente la variabile Label con il valore del titolo e url del video.
Potresti aiutarmi?
Grazie
Ciao Sara, nella variabile {{Label}} non è presente il titolo del video?
PS inviami una email a mz@inrisalto.it
Ciao Sara,
in realtà nella variabile {{Label}} hai il valore del titolo e url del video quindi potresti usare quello come discriminatore e magari farti dei report personalizzati su Google Analytics.
A presto!