Dans le développement Web, le suivi de la position de la souris est une technique fondamentale pour créer des interfaces utilisateur interactives. Les utilisateurs s'appuient sur cette fonctionnalité à diverses fins, telles que la manipulation d'images, la validation de formulaires et le contrôle du jeu. Cependant, il peut y avoir des cas où vous devez suivre la position de la souris périodiquement, à intervalles réguliers.
Par défaut, lorsque vous déplacez la souris sur une page Web, le navigateur déclenche une série d'événements : « mousemove », « mousedown » et « mouseup ». Historiquement, les programmeurs se sont appuyés sur des écouteurs d'événements pour suivre la position de la souris. L'événement « mousemove », en particulier, se déclenche en continu lorsque la souris se déplace, vous permettant de capturer les coordonnées de position à tout moment. Cependant, cette approche présente une limite : elle ne met à jour les données de position que lorsque la souris bouge réellement.
Que faire si vous avez besoin de mettre à jour les données de position à intervalles réguliers, même quand la souris est à l'arrêt ? Une solution possible consiste à utiliser une minuterie. Au lieu de vous fier uniquement aux écouteurs d'événements, vous pouvez configurer un minuteur qui appelle périodiquement une fonction pour interroger la position de la souris. Cette approche garantit que vous obtenez des mises à jour de position, que la souris bouge ou non.
Voici un extrait de code qui montre comment implémenter le suivi périodique de la position de la souris à l'aide d'une minuterie :
(function() { var mousePos; document.onmousemove = handleMouseMove; setInterval(getMousePosition, 100); // Set the timer to update every 100 milliseconds function handleMouseMove(event) { event = event || window.event; // IE-ism // If pageX/Y aren't available and clientX/Y are, calculate pageX/Y - logic taken from jQuery. // (This is to support old IE) if (event.pageX == null && event.clientX != null) { var eventDoc = (event.target && event.target.ownerDocument) || document; var doc = eventDoc.documentElement; var body = eventDoc.body; event.pageX = event.clientX + (doc && doc.scrollLeft || body && body.scrollLeft || 0) - (doc && doc.clientLeft || body && body.clientLeft || 0); event.pageY = event.clientY + (doc && doc.scrollTop || body && body.scrollTop || 0) - (doc && doc.clientTop || body && body.clientTop || 0); } mousePos = { x: event.pageX, y: event.pageY }; } function getMousePosition() { var pos = mousePos; if (!pos) { // We haven't seen any movement yet } else { // Use pos.x and pos.y } } })();
Notez que cette méthode nécessite à la fois des écouteurs d'événements et une minuterie pour fonctionner correctement. Il est recommandé d'effacer l'intervalle de temps lorsque le programme termine son exécution pour éviter une consommation inutile de ressources. De plus, n'oubliez pas de limiter le traitement effectué dans la fonction de minuterie pour minimiser l'impact sur les performances, surtout si les mises à jour sont fréquentes.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!