首頁 >後端開發 >php教程 >segmentfault无登陆进入 在一个界面登陆后 其他界面提示 已经登陆 需要重新加载

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

WBOY
WBOY原創
2016-06-06 20:34:141022瀏覽

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

回复内容:

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

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

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

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

<code>//登陆状态时输出的内容
<meta name="userId" value="1030000000334890" id="SFUserId">

//未登陆状态时输出的内容
<meta name="userId" value="" id="SFUserId">
</code>

相关的JS代码:

<code>    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('<span class="has-unread__count">' + e.data.events + "</span>"),
                        $("#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('<span class="badge">' + e.data.drafts + "</span>")), 0 !== e.data.invites && ($("#inviteCount .badge").remove(), $("#inviteCount").append('<span class="badge">' + e.data.invites + "</span>"))
            }
        })
    }


    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('<div class="alert alert-warning topframe js-alert">
<span class="content"></span><button type="button" class="close" data-dismiss="alert"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button>
</div>'),

    $(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('您已登录,请 <button class="btn btn-warning btn-xs" type="button" onclick="location.reload()">重新加载</button>').parent().show())
        })
    })
</code>

cookie、localStorge 都可以实现啊;

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

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn