一、需求说明
昨天后端开发人员让我实现一个网页锁屏,当时我一头雾水,问他为啥搞的跟安卓系统一样。他的回复是"看起来帅点"。
首先我们梳理下逻辑,先来个简化版的,用户长时间未操作时,返回登录页
二、思路
使用 mouseover 事件来监测是否有用户操作页面,写一个定时器间隔特定时间检测是否长时间未操作页面,如果是,退出登陆,清除token,返回登录页
三、实现
【1】在util文件夹下创建一个storage.js封装localStorage方法
export default { setItem(key, value) { value = JSON.stringify(value); window.localStorage.setItem(key, value) }, getItem(key, defaultValue) { let value = window.localStorage.getItem(key) try { value = JSON.parse(value); } catch {} return value || defaultValue }, removeItem(key) { window.localStorage.removeItem(key) }, clear() { window.localStorage.clear() }, }
【2】在util文件夹下创建一个astrict.js
每隔30s去检查一下用户是否过了30分钟未操作页面
// 引入路由和storage工具函数 import storage from '@/utils/storage' import router from "@/common/router" let lastTime = new Date().getTime() let currentTime = new Date().getTime() let timeOut = 30 * 60 * 1000 //设置超时时间: 30分钟 window.onload = function () { window.document.onmousedown = function () { stroage.setItem("lastTime", new Date().getTime()) } }; function checkTimeout() { currentTime = new Date().getTime() //更新当前时间 lastTime = stroage.getItem("lastTime"); if (currentTime - lastTime > timeOut) { //判断是否超时 // 清除storage的数据(登陆信息和token) storage.clear() // 跳到登陆页 if(router.currentRouter.name == 'login') return // 当前已经是登陆页时不做跳转 router.push({ name: 'login' }) } } export default function () { /* 定时器 间隔30秒检测是否长时间未操作页面 */ window.setInterval(checkTimeout, 30000); }
【2】在main.js引入astrict.js
import Astrict from '@/utils/astrict' Vue.use(Astrict)
四、锁屏
实现网页锁屏的思路和上面自动退出登录类似,稍微改动实现如下:
【1】用户长时间未操作,弹出设置锁屏密码弹框设置锁屏密码
【2】密码(password)和锁屏状态(isLock)存入localStorage 和vuex
【3】设置成功后跳转到锁屏登录页
【4】 在路由里面判断vuex里面的isLock(为true锁屏状态不能让用户后退url和自行修改url跳转页面否则可以)
【5】用户在锁屏登录页输入刚刚设置的锁屏密码,即可解开锁屏
总结
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。