Home >Backend Development >PHP Tutorial >segmentfault无登陆进入 在一个界面登陆后 其他界面提示 已经登陆 需要重新加载
这个怎么实现的
求技术关键词
这个怎么实现的
求技术关键词
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 的数据,如果没有,就发一条消息的接口请求看看是不是需要登陆的提示,没有则显示重新加载的提示。