Home >Web Front-end >JS Tutorial >How Can I Detect Idle Time in JavaScript to Optimize Content Pre-fetching and Pre-loading?

How Can I Detect Idle Time in JavaScript to Optimize Content Pre-fetching and Pre-loading?

DDD
DDDOriginal
2024-12-26 02:30:10367browse

How Can I Detect Idle Time in JavaScript to Optimize Content Pre-fetching and Pre-loading?

Detecting Idle Time in JavaScript: A Guide for Pre-fetching and Pre-loading Content

In web development, detecting idle time can be crucial for optimizing user experience. Idle time, defined as a period of user inactivity or minimal CPU usage, presents an opportunity to pre-fetch or pre-load content, reducing page load times and enhancing responsiveness.

Implementing Idle Time Detection in Vanilla JavaScript

To enable idle time detection in Vanilla JavaScript, utilize the following approach:

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
    }
};

Initialization and Customizations

Once the inactivityTime function is defined, initialize it where desired (e.g., onPageLoad):

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

You can further customize the event listeners by adding more DOM events, including:

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

Or, register events dynamically using an array:

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

Note that window.onscroll will not trigger if scrolling occurs within a scrollable element. To address this, include the third argument in window.addEventListener('scroll', resetTimer, true) to capture the event during the capture phase.

The above is the detailed content of How Can I Detect Idle Time in JavaScript to Optimize Content Pre-fetching and Pre-loading?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn