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 的数据,如果没有,就发一条消息的接口请求看看是不是需要登陆的提示,没有则显示重新加载的提示。

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

PHP和Python各有優勢,選擇依據項目需求。 1.PHP適合web開發,尤其快速開發和維護網站。 2.Python適用於數據科學、機器學習和人工智能,語法簡潔,適合初學者。

PHP在電子商務、內容管理系統和API開發中廣泛應用。 1)電子商務:用於購物車功能和支付處理。 2)內容管理系統:用於動態內容生成和用戶管理。 3)API開發:用於RESTfulAPI開發和API安全性。通過性能優化和最佳實踐,PHP應用的效率和可維護性得以提升。

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP仍然具有活力,其在現代編程領域中依然佔據重要地位。 1)PHP的簡單易學和強大社區支持使其在Web開發中廣泛應用;2)其靈活性和穩定性使其在處理Web表單、數據庫操作和文件處理等方面表現出色;3)PHP不斷進化和優化,適用於初學者和經驗豐富的開發者。

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP和Python各有優劣,選擇取決於項目需求和個人偏好。 1.PHP適合快速開發和維護大型Web應用。 2.Python在數據科學和機器學習領域佔據主導地位。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。
