"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Comment puis-je détecter le temps d’inactivité des utilisateurs en JavaScript ?

Comment puis-je détecter le temps d’inactivité des utilisateurs en JavaScript ?

Publié le 2024-12-21
Parcourir:866

How Can I Detect User Idle Time in JavaScript?

Détection du temps d'inactivité en JavaScript

Introduction :

Dans le développement Web, comprendre l'activité des utilisateurs est crucial pour optimiser les performances et offrir une meilleure expérience utilisateur. La détection du temps d'inactivité, défini comme une période d'inactivité ou une faible utilisation du processeur, peut vous aider à déclencher des actions telles que le préchargement de contenu ou l'authentification de l'utilisateur.

Mise en œuvre de JavaScript :

Pour détecter temps d'inactivité en JavaScript, vous pouvez utiliser l'approche JavaScript vanille suivante :

Extrait de code :

var inactivityTime = function () {
    var time;
    window.onload = resetTimer;
    // DOM Events
    document.onmousemove = resetTimer;
    document.onkeydown = resetTimer;

    function logout() {
        alert("You are now logged out.")
        //location.href = 'logout.html'
    }

    function resetTimer() {
        clearTimeout(time);
        time = setTimeout(logout, 3000)
        // 1000 milliseconds = 1 second
    }
};

Utilisation :

Pour initialiser la détection du temps d'inactivité, appelez la fonction inactivityTime() après le chargement de la page :

window.onload = function() {
  inactivityTime();
}

Personnalisation :

Vous pouvez ajouter plus d'événements DOM pour surveiller l'activité des utilisateurs. Certains des événements les plus couramment utilisés sont :

document.onload = resetTimer;
document.onmousemove = resetTimer;
document.onmousedown = resetTimer; // touchscreen presses
document.ontouchstart = resetTimer;
document.onclick = resetTimer;     // touchpad clicks
document.onkeydown = resetTimer;   // onkeypress is deprectaed
document.addEventListener('scroll', resetTimer, true); // improved; see comments

Pour une meilleure personnalisation, vous pouvez utiliser un tableau pour enregistrer plusieurs événements :

window.addEventListener('load', resetTimer, true);
var events = ['mousedown', 'mousemove', 'keypress', 'scroll', 'touchstart'];
events.forEach(function(name) {
 document.addEventListener(name, resetTimer, true);
});

En personnalisant les événements que vous surveillez, vous pouvez adapter la détection des temps d'inactivité aux besoins spécifiques de votre application.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3