[AGGIORNAMENTO 01 Dicembre 2022]

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.

Prerequisito

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.

Step 1 – Crea l’Attivatore

Per prima cosa crea l’Attivatore. Entra quindi nel tuo account di Google Tag Manager, poi fai così:

  • Attivatori > Nuovo > Configurazione attivatore.
  • Tipo di attivatore: Pronto per DOM.
  • Attiva su: Alcuni eventi pronti per DOM.
  • In Attiva quando seleziona le pagine che contengono i video che vuoi tracciare. Nel mio esempio ho impostato: Page URL contiene esempio/pagina-di-esempio/.
  • Salva l’Attivatore nominandolo “PaginaVideoYoutube”.attivatore tracciare video youtube embeddati google tag manager

Step 2 – Crea il Tag

Crea quindi un nuovo Tag.

  • Clicca su Tag > Nuovo > Configurazione tag.
  • Tipo di tag: Tag HTML personalizzato.
  • Incolla il seguente codice:
<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>

 

  • In Attivazione seleziona l’Attivatore appena creato, cioè “PaginaVideoYoutube”.
  • Rinomina il Tag in modo appropriato, ad esempio “Video YouTube”.
  • Salva.

PICCOLO TIP

Se hai problemi prova con la libreria minificata che trovi a questo link.

tag tracciare video youtube embeddati google tag manager

 

Step 3 – Visualizza in Anteprima

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.

 

datalayer tracciare video youtube embeddati google tag manager

Per passare i dati degli elementi action e label a Google Analytics dovrai creare delle Variabili.

Step 4 – Crea le Variabili

  • Vai quindi in Variabili > Variabili definite dall’utente > Nuova > Configurazione variabile.
  • Tipo di variabile: Variabile di livello dati.
  • Nome variabile livello dati: action.
  • Salva la Variabile nominandola, appunto, “Action”.

Allo stesso modo, crea la Variabile “Label”.

variabile action tracciare video youtube embeddati google tag manager

Step 5 – Crea il secondo Tag

L’ultimo step è creare un Tag per passare queste Variabili appena create a Google Analytics.

  • Tag > Nuovo > Configurazione tag.
  • Tipo di tag: Universal Analytics.
  • Tipo di monitoraggio: Evento.
  • Categoria: Video.
  • Azione: {{Action}}
  • Etichetta: {{Label}}
  • Seleziona la variabile di Google Analytics oppure abilita l’override e inserisci, nel campo ID di monitoraggio, {{gaID}} (la Costante personalizzata che corrisponde al tuo codice di monitoraggio Analytics). Oppure inserisci semplicemente il tuo codice UA di Analytics.
  • Clicca su Attivazione. A questo punto ti comparirà una finestra con tutti gli Attivatori già creati. Clicca sul simbolo “+” in alto a destra per creare un nuovo Attivatore.
  • Per il nuovo Attivatore scegli il tipo: “Evento personalizzato”.
  • Nome evento: “youtube”.
  • Nomina l’Attivatore anch’esso “Youtube” e salva

attivatore video tracciare youtube embeddati google tag manager

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.

tag2 tracciare video youtube embeddati google tag manager

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.

Nota

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!

 

Condividi anche tu Google Tag Manager!
  • Reply

    Nicola

    03 04 2019

    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!

    • Matteo Zambon

      08 04 2019

      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://www.tagmanageritalia.it/richiedi-consulenza/

  • Reply

    Fabio

    24 09 2018

    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

    • Matteo Zambon

      25 09 2018

      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!

    • Fabio

      25 09 2018

      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?

    • Matteo Zambon

      25 09 2018

      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.

    • Fabio

      25 09 2018

      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?

    • Matteo Zambon

      25 09 2018

      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

      🙂

    • Fabio

      25 09 2018

      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 ?!

    • Matteo Zambon

      27 09 2018

      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. 🙂

  • Reply

    Fabio

    15 12 2017

    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

    • Matteo Zambon

      15 12 2017

      Ciao Fabio, usa l’attivatore nativo di GTM: https://www.tagmanageritalia.it/guida-base-come-tracciare-video-youtube-google-tag-manager/

      Fammi sapere 🙂

    • Fabio

      15 12 2017

      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

    • Matteo Zambon

      18 12 2017

      Ciao Fabio,

      hai inserito la costante di Google Analytics nella sezione “ID di monitoraggio”?

    • Fabio

      18 12 2017

      Ciao Matteo,

      sì. Ho provato sia inserendo direttamente l’ID monitoraggio, sia creando e inserendo la costante di GA.

    • Matteo Zambon

      18 12 2017

      Riesci a mostrarmi uno screen della configurazione del tag e dell’attivatore?

  • Reply

    Francesco Caruccio

    16 11 2017

    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)

    • Matteo Zambon

      16 11 2017

      Ciao Francesco,

      sì certo, puoi farlo con le API 😉

  • Reply

    Gian

    15 12 2016

    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

  • Reply

    Giorgia

    29 06 2016

    Buongiorno,
    ma se il video non fosse di youtube, bensì avesse una fonte differente?
    Grazie

  • Reply

    Sara

    23 06 2016

    Grazie per la risposta!
    Proverò a fare come consigli.

  • Reply

    Sara

    22 06 2016

    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!

    • Matteo Zambon

      22 06 2016

      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!

    • Sara

      27 06 2016

      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

    • Matteo Zambon

      27 06 2016

      Ciao Sara, nella variabile {{Label}} non è presente il titolo del video?
      PS inviami una email a mz@inrisalto.it

Hai ancora qualche dubbio?
Chiedi pure qui sotto, sarò pronto a risponderti!

Il tuo indirizzo email non sarà pubblicato. I campi obbligatori sono contrassegnati *