微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – 是否可以知道用户在页面上花了多长时间?

假设我有一个浏览器扩展程序,它运行用户访问的JS页面.

是否有“outLoad”事件或类似事件开始计算并查看用户页面上花了多长时间?

解决方法

我假设您的用户打开一个标签,浏览一些网页,然后转到另一个网页,返回到第一个标签等.您想要计算用户花费的确切时间.另请注意,用户可能会打开网页并保持其正常运行但只是离开.一小时后回来,然后再次访问该页面.您不希望将他离开计算机的时间计算在网页上花费的时间.为此,下面的代码每5分钟进行一次docus检查.因此,您的实际时间可能会偏离5分钟的粒度,但您可以根据需要调整间隔以检查焦点.另请注意,用户可能只是盯着视频超过5分钟,在这种情况下,以下代码将不计算在内.您必须运行智能代码来检查是否有闪存运行或其他东西.

这是我在内容脚本中所做的(使用jQuery):

$(window).on('unload',window_unfocused);
$(window).on("focus",window_focused);
$(window).on("blur",window_unfocused);
setInterval(focus_check,300 * 1000);

var start_focus_time = undefined;
var last_user_interaction = undefined;

function focus_check() {
    if (start_focus_time != undefined) {
        var curr_time = new Date();
        //Lets just put it for 4.5 minutes                                                                                
    if((curr_time.getTime() - last_user_interaction.getTime()) > (270 * 1000)) {
            //No interaction in this tab for last 5 minutes. Probably idle.                                               
            window_unfocused();
        }
    }
}

function window_focused(eo) {
    last_user_interaction = new Date();
    if (start_focus_time == undefined) {
    start_focus_time = new Date();                                                               
    }
}

function window_unfocused(eo) {
    if (start_focus_time != undefined) {
    var stop_focus_time = new Date();
    var total_focus_time = stop_focus_time.getTime() - start_focus_time.getTime();
    start_focus_time = undefined;
    var message = {};
        message.type = "time_spent";
        message.domain = document.domain;
        message.time_spent = total_focus_time;
        chrome.extension.sendMessage("",message);
    }
}

原文地址:https://www.jb51.cc/js/156011.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐