当前位置:Gxlcms > PHP教程 > segmentfault无登陆进入在一个界面登陆后其他界面提示已经登陆需要重新加载

segmentfault无登陆进入在一个界面登陆后其他界面提示已经登陆需要重新加载

时间:2021-07-01 10:21:17 帮助过:3人阅读

这个怎么实现的
求技术关键词

回复内容:

这个怎么实现的
求技术关键词

http://static.segmentfault.com/build/qa/js/question.2613f2a2.js

因为文件是经过压缩过的, 所以我只说一下主要的部分:
根据不同的浏览器对于当窗口获得焦点时的事件名称不同, 绑定相应的窗口获得焦点的事件,
然后在事件触发的时候 发 ajax 检测当前的登陆状态, 如果是由 未登陆 变为 登陆状态, 则显示你所看到的那句话. 如果是登陆状态, 还是会发 ajax 检测当前的登陆状态, 并执行相应的js, 并且设置计时器setInterval 每隔60秒检测一次登陆状态.

在进入页面的时候, 后端会在页面中会输出

//登陆状态时
输出的内容 //未登陆状态时输出的内容

相关的JS代码:

    function a() {
        $.getJSON("/api/user/stat", function(e) {
            if (0 === e.status) {
                var t = $("title");
                e.data.events > 0 ? 
                    (e.data.events > 99 && (e.data.events = "99+"), 
                        $("#messageCount").siblings(".has-unread__count").remove(),
                        $("#messageCount").after('' + e.data.events + ""),
                        $("#m-messageCount").text(e.data.events),
                    $(".mobile-menu__unreadpoint").show(),
                    t.text(/^\(\d+[\+]?\)/.test(t.text()) ? t.text().replace(/^\(\d+[\+]?\)/, "(" + e.data.events + ")") : "(" + e.data.events + ")" + $("title").text())
                    ) : 0 === e.data.events && ($(".has-unread__count").remove(), t.text(t.text().replace(/^\(\d+[\+]?\)/, ""))), 0 !== e.data.drafts && ($("#draftCount .badge").remove(), $("#draftCount").append('' + e.data.drafts + "")), 0 !== e.data.invites && ($("#inviteCount .badge").remove(), $("#inviteCount").append('' + e.data.invites + ""))
            }
        })
    }


    var r = {_: window.SF.token,staticUrl: window.SF.staticUrl,userId: $("#SFUserId").attr("value"),userRank: $("#SFUserRank").attr("value"),getMessage: a,login: t.login || i};

    var s, l;

    "undefined" != typeof document.hidden ? (s = "hidden", l = "visibilitychange") : "undefined" != typeof document.mozHidden ? (s = "mozHidden", l = "mozvisibilitychange") : "undefined" != typeof document.msHidden ? (s = "msHidden", l = "msvisibilitychange") : "undefined" != typeof document.webkitHidden && (s = "webkitHidden", l = "webkitvisibilitychange"), $("body").prepend(''),

    $(document).on(l, function() {
        document[s] ? clearInterval(o) : r.userId ? (a(), o = setInterval(a, 6e4)) : $.getJSON("/api/user/stat", function(e) {
            0 == e.status && ($("body").addClass("have-notify"), $(".js-alert").find(".content").html('您已登录,请 ').parent().show())
        })
    })

cookie、localStorge 都可以实现啊;

判断登录的应该是统一的方法吧,登录后把一个标识写入 cookie或localStorge就可以了。

tab 页激活时检测是否已经有 session 的数据,如果没有,就发一条消息的接口请求看看是不是需要登陆的提示,没有则显示重新加载的提示。

人气教程排行