Tracking de clic dans une iframe

Tracking de clic dans une iframe

Tutoriel publié en mars 2013 par Galdon dans la catégorie jQuery

En utilisant javascript il est très facile de détecter les clics sur n'importe quel élément d'une page web, c'est encore plus facile avec un framework comme jQuery. Par contre c'est impossible à faire sur une iframe et son contenu.

La raison à ça est assez simple à comprendre : une iframe c'est comme un navigateur imbriqué dans une page web (exactement comme si la page ciblée par l'iframe se trouvait dans un autre onglet ou dans une autre fenêtre de navigateur).

En javascript, on n’a pas accès aux autres onglets pour des raisons évidentes de sécurité, et bien pour les iframe c'est la même chose, les navigateurs ne donnent pas accès au contenu d'une iframe via Javascript.

Lorsque l'iframe se trouve sur le même domaine que la page parente, le navigateur donne accès au contenu de l'iframe depuis la page parente, et vice-versa, mais c'est la seule exception à ces règles de sécurité.

Pourtant, il est quand même possible de détecter les clics sur une iframe en utilisant habillement l'événement blur et quelques variables...

Dans ce tutoriel, je vais donc vous présenter une technique "maison" qui permet de faire du tracking de clics sur une iframe (en utilisant jQuery), que l'on peut utiliser pour de nombreuses applications : tracking de clic sur un bouton "J'aime" Facebook, un bouton Google +1, un player youtube ou encore les clics sur les annonces Google Adsense (ou une autre régie de pub).

C'est parti !

Tracking de clic sur une iframe

Dans cette partie, je vais vous expliquer le fonctionnement général, le principe qui permet de détecter les clics.

Pour ça, on va travailler sur une page web très simple qui contient une iframe, comme ceci :

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>Tracker les clics dans une iframe avec jQuery</title>
	<link href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.1/css/bootstrap.min.css" rel="stylesheet">
	<style>
	body{background:#efefef; padding:15px 20px;}
	.iframetrack{margin:20px 0;}
	#consoleDebug{position:fixed; top:30px; right:30px; z-index:9999; background:rgba(0,0,0,0.3);}
	#consoleDebug .alert{margin:20px;}
	</style>
	<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
</head>
<body>
	<p>Element actif : <span class="label" id="actif"></span></p>
	<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Nam cursus. Morbi ut mi. Nullam enim leo, egestas id, condimentum at, laoreet mattis, massa. Sed eleifend nonummy diam.</p>
	<div class="iframetrack">
		<iframe width="468" height="110" src="./sample-iframe/red.html" frameborder="0" allowtransparency="true" scrolling="no"></iframe>
	</div>
	<p>Sed eleifend nonummy diam. Praesent mauris ante, elementum et, bibendum at, posuere sit amet, nibh.</p>
	<div id="consoleDebug"></div>
</body>
</html>

Le div #consoleDebug va simplement servir à afficher un message à chaque fois qu'un clic est détecté.

Au chargement d'une page web, le navigateur donne par défaut le focus à l'élément <body>, qui correspond en gros à toute la page web.

Qu'est-ce que le focus ?

Une page web est composée d'une arborescence d'éléments qu'on appelle le DOM. Certains de ses éléments comme des champs de formulaire (<input>, <textarea>), ou les liens (<a>) peuvent êtres marqués comme l'élément actif. C'est ça qu'on appelle le focus.

Lorsqu'un champ de formulaire a le focus, le curseur clignote à l'intérieur, et lorsqu'on appuie sur des touches du clavier, on écrit dans ce champ. En jQuery, on peut détecter lorsqu'un élément obtiens le focus, en utilisant l'événement .focus().

Mais ça n'est pas tout, il existe le contraire de focus, il s'agit de l'événement blur. Cet événement survient lorsqu'un élément perd le focus, ce qui est le cas par exemple lorsqu'on change de champ dans un formulaire.

Pourquoi je vous parle de ça ?
Et bien parce que l'événement blur va nous permettre de détecter le clic sur une iframe, car lorsqu'on clique sur une iframe, la page web perd le focus.

Le problème c'est qu'il y a plein d'autres cas dans lesquels la page reçoit l'événement blur, en voici quelques exemples :

  • L'utilisateur change d'onglet
  • L'utilisateur clique sur une autre fenêtre que celle du navigateur web qui affiche la page

Du coup il va falloir être en mesure de savoir si le blur a été provoqué par un clic sur une iframe, ou par autre chose.

Quand la souris survole une iframe ou au contraire revient dans la page après avoir survolé l'iframe, les événements mouseover et mouseout se produisent. Donc il est très facile de savoir si la souris est au dessus d'une iframe ou pas, en surveillant la frontière page web/iframe grâce à ces 2 événements.

Et bien voici le code javascript qui permet de faire tout ça avec jQuery :

jQuery(document).ready(function($){
	// Affichage de l'élément actif (pour aider à comprendre ce qui se passe)
	setInterval(function(){
		$('#actif').text(document.activeElement.tagName);
	}, 100);
	
	// Initialisation variable
	iframe_survol = false;
	
	// Surveillance frontière
	$('.iframetrack iframe').mouseover(function(){
		iframe_survol = true;
	}).mouseout(function(){
		iframe_survol = false;
	});
	
	// On donne le focus à la fenêtre au chargement
	$(window).focus();
	
	// Ecoute blur
	$(window).blur(function(e){
		$('<div class="alert alert-info">').html("Clic sur l'iframe").appendTo('#consoleDebug').delay(3000).fadeOut();
	});
	
	// Retour du focus sur la page au survol
	$(document).mousemove(function(e){
		if( document.activeElement.tagName == 'IFRAME' ){
			$(window).focus();
		}
	});
});

Voilà ce que ça donne en live :

Tester /ressources/exemple/jquery-iframe-track/simple.html
Iframe tracking
Tracker les clics dans une iframe avec jQuery

Cette technique fonctionne, mais elle est assez lourde à mettre en place, et ne permet pas de gérer plusieurs iframes.

De plus, elle n'est pas compatible avec tous les navigateurs : Internet Explorer gère le blur de manière très différente des autres navigateurs, et certaines fonctions ne marchent pas sur Firefox, comme le $(window).focus();.

Plugin jQuery : iframeTracker

iframeTracker est un plugin jQuery que j'ai moi-même créé, et qui permet de faire la même chose que ce qui a été présenté dans la première partie, sauf qu'il est compatible avec tous les navigateurs (j'ai résolu les soucis de compatibilité avec IE8 et Firefox grâce à une astuce un peu complexe qu'il n'est pas nécessaire d'expliquer dans ce tutoriel).

De plus, ce plug-in permet de gérer un nombre d'iframe illimité, et d'effectuer différentes actions au survol de ces iframes grâce à des callback (fonctions appelées automatiquement par le plugin en réaction à des événements).

Je vous conseille vivement d'utiliser ce plugin plutôt que le code vu dans la première partie, qui n'est là que pour montrer le fonctionnement avec un exemple assez simple.

Vous pouvez le télécharger ici (version utilisée pour ce tutoriel, avec les commentaires en français) : jquery.iframetracker.fr.js ou alors sur GitHub : iframeTracker-jquery.

Voici comment il s'utilise :

jQuery(document).ready(function($){
	// Facebook iframe
	$('.socialiframetrack_facebook iframe').iframeTracker({
		blurCallback: function(){
			$('<div class="alert alert-info">').html('Click on Facebook iframe').appendTo('#consoleDebug').delay(3000).fadeOut();
		}
	});
	
	// Autres iframes (entourées par un élément de classe CSS .iframetrack)
	$('.iframetrack iframe').iframeTracker({
		blurCallback: function(){
			$('<div class="alert alert-info">').html('Click on iframe : #' + this._overId).appendTo('#consoleDebug').delay(3000).fadeOut();
		},
		overCallback: function(element){
			// Mémorisation de l'id de l'iframe survollée
			this._overId = $(element).parents('.iframetrack').attr('id');
		},
		outCallback: function(element){
			// Reset lorsque la souris sort de l'iframe et revient dans la fenêtre
			this._overId = null;
		},
		_overId: null
	});
});

C'est très simple, il faut utiliser un sélecteur qui match toutes les iframes que vous voulez "écouter" avec un sélecteur jQuery, et d'appeler la fonction iframeTracker en lui passant en paramètre un objet qui possède ces slots :

  • blurCallback
    obligatoire
    Cette fonction est appelée lorsque la fenêtre perd le focus alors que le pointeur de la souris est au dessus d'une iframe parmi celles matchées par le sélecteur (car il peut y en avoir plusieurs)
  • overCallback
    facultatif
    Cette fonction est appelée lorsque la souris entre dans une iframe écoutée par le sélecteur.
    Elle prend en paramètre l'élément qui représente l'iframe survolée.
    C'est très pratique car on peut alors mémoriser l'iframe actuellement survolée lorsque le sélecteur match plusieurs iframe. Dans l'exemple, je stocke cette information dans la variable _overId que j'utilise ensuite dans le blurCallback.
  • outCallback
    facultatif
    Réciproque de overCallback, cette fonction est appelée lorsque la souris ressort de l'iframe pour revenir dans la page web.

Ensuite vous pouvez parfaitement ajouter des attributs supplémentaires pour stocker les différentes variables dont vous avez besoin dans vos callbacks, comme je l'ai fait avec _overId.

Voilà ce que ça donne :

Tester /ressources/exemple/jquery-iframe-track/
Demo jQuery iframeTracker
Exemple d'utilisation du plugin jQuery iframeTracker

Encore faim ? allez lire ça : zombie poulpe !

Tutoriaux similaires
36 commentaires :
Seuls les 10 derniers commentaires sont affichés.
Cliquez ici pour afficher tous les commentaires
commentaire n°3140 par mvedie
mvedie mardi 18 août 2015, 18:26
Bonjour,

Un gros mercis et un grand bravo pour ce "petit" code qui m'a fait economiser un certain temps :). J'avais commencer à le faire lorsque je me suis dis, tiens ça existe peut être.

Merci beaucoup.

Cdt, Mathieu.
commentaire n°3294 par bittu
bittu vendredi 22 avril 2016, 17:26
hi,
Thank you for the script and even more for the explanation on how it works. Helped a lot, cant tank you enough
commentaire n°3428 par Mikado
Mikado jeudi 22 décembre 2016, 16:37
Super tuto, merci beaucoup du coup de main. Cependant dans la premiere partie la variable iframe_survol n'est pas exploite. Ce qui a pour effet d'activer le blur quand on change d'onglet.
Il suffirait juste d'ajouter :
$(window).blur(function(e){
if(iframe_survol) {
}
}

pour le faire fonctionner
commentaire n°3482 par strabsquad
strabsquad mardi 28 mars 2017, 17:01
Hello :)

Est-ce que tu penses que c'est enviseagable pour tracker des events dans google analytics ?
commentaire n°3511 par Az
Az lundi 12 juin 2017, 09:12

If you place the two iframes side by side (with margin/padding = 0) you'll get a bug. If you click on the first iframe you'll get a message about click. If you move your mouse to the second iframe and click on it you'll also se a message about click. BUT if you'll try to move mouse to the first iframe and click again you'll get a bug. You'll never see a message about click.

To solve this issue you have to add $(window).focus(); on mouseout event.

// Surveillance frontière
$('.iframetrack iframe').mouseover(function(){
iframe_survol = true;
}).mouseout(function(){
iframe_survol = false;
$(window).focus();
});
commentaire n°3716 par Fabio
Fabio jeudi 11 octobre 2018, 13:07
Bonjour, j'utilise le plugin mentionné dans le sujet. Très gentil et utile. J'aimerais savoir comment détecter quel bouton de la souris a cliqué sur les iframes et si cela se produit en tapant sur un appareil mobile. Merci.
commentaire n°11892 par Olivia John
Olivia John mercredi 9 février 2022, 04:10
Votre mari ou votre petit ami vous a-t-il quitté pour une autre femme ? contact : Le Dr Emwanta est certainement le meilleur lanceur de sorts et son résultat est garanti à 100 %. J'ai 42 ans. Mon mari m'a quitté pour une autre femme il y a 3 mois et depuis lors, ma vie a été remplie de douleurs, de chagrin et de chagrin parce qu'il était mon premier amour avec qui j'ai passé toute ma vie. Un de mes amis m'a dit qu'il avait vu des témoignages d'un lanceur de sorts appelé. Dr Emwanta qu'il peut ramener l'amant dans les 48 heures, j'en ris et j'ai dit que je ne suis pas intéressé mais à cause de l'amour que mon amie avait pour moi, elle a consulté le grand Dr Emwanta en mon nom et à ma plus grande surprise après 48 heures plus tard mon mon mari m'a appelé pour la toute première fois après trois mois qu'il me manque et qu'il est tellement désolé pour tout ce qu'il m'a fait traverser. Il est revenu vers moi et maintenant nous sommes heureux ensemble. Je n'arrive toujours pas à y croire, car c'est très incroyable. Merci Dr Emwanta d'avoir ramené mon amant et aussi à ma charmante amie qui a intercédé en mon nom, je recommande vraiment fortement Dr Emwanta. Pour tous ceux qui ont des problèmes en ce moment, voici son contact, envoyez-lui un e-mail à: (dremwanta@gmail.com) ou WhatsApp +2348163136916, bonne chance toujours à vous tout sourire émotion
commentaire n°11893 par Olivia John
Olivia John mercredi 9 février 2022, 04:14
Votre mari ou votre petit ami vous a-t-il quitté pour une autre femme ? contact : Le Dr Emwanta est certainement le meilleur lanceur de sorts et son résultat est garanti à 100 %. J'ai 42 ans. Mon mari m'a quitté pour une autre femme il y a 3 mois et depuis lors, ma vie a été remplie de douleurs, de chagrin et de chagrin parce qu'il était mon premier amour avec qui j'ai passé toute ma vie. Un de mes amis m'a dit qu'il avait vu des témoignages d'un lanceur de sorts appelé. Dr Emwanta qu'il peut ramener l'amant dans les 48 heures, j'en ris et j'ai dit que je ne suis pas intéressé mais à cause de l'amour que mon amie avait pour moi, elle a consulté le grand Dr Emwanta en mon nom et à ma plus grande surprise après 48 heures plus tard mon mon mari m'a appelé pour la toute première fois après trois mois qu'il me manque et qu'il est tellement désolé pour tout ce qu'il m'a fait traverser. Il est revenu vers moi et maintenant nous sommes heureux ensemble. Je n'arrive toujours pas à y croire, car c'est très incroyable. Merci Dr Emwanta d'avoir ramené mon amant et aussi à ma charmante amie qui a intercédé en mon nom, je recommande vraiment fortement Dr Emwanta. Pour tous ceux qui ont des problèmes en ce moment, voici son contact, envoyez-lui un e-mail à: (dremwanta@gmail.com) ou WhatsApp +2348163136916, bonne chance toujours à vous tout sourire émotion
commentaire n°12036 par Anais Marini
Anais Marini mardi 8 mars 2022, 13:37
Votre mari ou votre petit ami vous a-t-il quitté pour une autre femme ? contact : Le Dr Emwanta est certainement le meilleur lanceur de sorts et son résultat est garanti à 100 %. J'ai 42 ans. Mon mari m'a quitté pour une autre femme il y a 3 mois et depuis lors, ma vie a été remplie de douleurs, de chagrin et de chagrin parce qu'il était mon premier amour avec qui j'ai passé toute ma vie. Un de mes amis m'a dit qu'il avait vu des témoignages d'un lanceur de sorts appelé. Dr Emwanta qu'il peut ramener un amant dans les 48 heures, j'en ris et j'ai dit que je ne suis pas intéressé mais à cause de l'amour que mon amie avait pour moi, elle a consulté le grand Dr Emwanta en mon nom et à ma plus grande surprise après 48 heures plus tard, mon mon mari m'a appelé pour la toute première fois après trois mois qu'il me manque et qu'il est tellement désolé pour tout ce qu'il m'a fait traverser. Il est revenu vers moi et maintenant nous sommes heureux ensemble. Je n'arrive toujours pas à y croire, car c'est très incroyable. Merci Dr Emwanta d'avoir ramené mon amant et aussi à ma charmante amie qui a intercédé en mon nom, je recommande vraiment fortement Dr Emwanta. Pour tous ceux qui ont des problèmes en ce moment, voici son contact, envoyez-lui un e-mail à: (dremwanta@gmail.com) ou WhatsApp +2348163136916, bonne chance toujours à vous tout sourire émotion
commentaire n°12223 par Rose
Rose lundi 21 mars 2022, 07:57
Je n'avais jamais cru au lancement de sorts jusqu'à ce que je rencontre le Dr Ogbetta, un lanceur de sorts puissant qui m'a aidé à redevenir une personne heureuse. Je m'appelle Rose, après 4 ans de mariage brisé, mon mari m'a laissé deux enfants. J'avais l'impression que ma vie était sur le point de se terminer et j'ai failli me suicider, j'étais émotionnellement déprimée pendant très longtemps. Grâce à un grand lanceur de sorts appelé Dr Ogbetta que j'ai rencontré en ligne un jour fatidique alors que je naviguais sur Internet, j'ai rencontré de nombreux témoignages sur ce grand lanceur de sorts particulier sur la façon dont il a aidé tant de gens. il a aidé des gens à ramener leur ancien amant, certains ont témoigné qu'il restaure l'utérus, guérit le cancer et d'autres maladies, etc. Je suis également tombé sur un témoignage, il s'agissait d'une femme appelée Anita, elle a témoigné de la façon dont son sort l'a rendue enceinte après tant d'années de nudité et à la fin de son témoignage, elle a laissé tomber l'adresse e-mail du Dr Ogbetta. Après avoir lu tout cela, j'ai décidé d'essayer et je l'ai contacté et lui ai expliqué mon problème et il m'a assuré que mon mari m'appellerait et demanderait pardon mais je pensais que cela ne fonctionnerait pas. Quand il eut fini de lancer le sort, le lendemain, mon mari m'a appelé et il demandait pardon, comme l'a dit le Dr Ogbetta. Ce n'est pas un lavage de cerveau et après que le sort a été lancé, j'ai réalisé que mon mari m'aimait comme jamais auparavant et le lanceur de sorts l'a ouvert pour savoir combien je l'aime et combien d'amour nous devons partager. Nous sommes encore plus heureux maintenant qu'avant. Le Dr Ogbetta est vraiment un homme doué et je n'arrêterai pas de le publier car c'est un homme merveilleux. Si vous avez un problème et que vous cherchez un vrai lanceur de sorts pour résoudre tous vos problèmes, contactez le Dr Ogbetta maintenant sur drogbettaspellhome@gmail.com ou whatsapp : +2349067874181
facultatif
Facebook Twitter RSS Email
Forum Excel
Venez découvrir le nouveau forum excel question/réponse à la stackoverflow.com !
Forum Excel
hit parade n'en a rien a foutre du W3C Positionnement et Statistiques Gratuites Vincent Paré