vue禁止浏览器F5进行刷新和监听浏览器刷新事件
项目中有个这样的需求:
进入视频播放页后,添加一个标识,为了防止用户一次播放多个视频,当离开该页面后,如果是从当前正在播放的视频页面离开的,则离开播放页时清除标识,如果是不是则不清除,并且禁止用户按F5进行页面刷新,当用户在正在播放的视频页按浏览器刷新按钮清除标识,当用户复制的视频播放页面url打开的页面,按浏览器刷新按钮,不清除标识。
用户进入视频播放页有两种途径:
1.从列表页点击视频进入视频播放页
2.复制视频播放链接新打开一个窗口粘贴上去
为了解决用户粘贴播放视频url也能正常播放,于是将播放视频的参数放到 params 中,当用户复制链接时,就获取不到播放视频需要的参数了,就直接给用户提示例如:

当用户直接复制链接跳到播放页,再从播放页跳至列表页时不清除,但当用户是从列表页跳至播放页,再在该播放页点击浏览器刷新按钮,则需要清除标识,否则用户再回到列表页点击课件播放时一直提示

解决方案:
列表页跳至播放页:
this.$router.push({
name: 'coursewarePlayback',
// path: '/coursewarePlayback',
params: {
Ids: data.id,
fileId: data.resourceFileId
}
})
播放页面:
mounted() {
this.haveSeek = false
// 先判断是否是复制的 url 进入到播放页面
if (!this.$route.params.Ids && !this.$route.params.fileId) {
this.$message({
message: '暂未获取到视频信息,请从列表页重新打开',
type: 'warning'
});
return
}
//阻止F5刷新
this.stopF5Refresh()
//监听刷新事件
window.addEventListener('beforeunload', e => this.beforeunloadHandler(e))
this.getDetailsAct(this.$route.params.Ids)
this.ideovSource = this.ideovUrl + this.$route.params.fileId + "/output.m3u8"
// 初始化播放器
const that = this
this.player = new Aliplayer({
id: "J_prismPlayer", // 容器id
source: this.ideovSource,//视频地址
// cover: "http://cdn.img.mtedu.com/images/assignment/day_3.jpg", //播放器封面图
autoplay: true, // 是否自动播放
width: "100%", // 播放器宽度
height: "610px", // 播放器高度
playsinline: true,
"skinLayout": [
{
"name": "bigPlayButton",
"align": "blabs",
"x": 500,
"y": 300
},
{
"name": "H5Loading",
"align": "cc"
},
{
"name": "errorDisplay",
"align": "tlabs",
"x": 0,
"y": 0
},
{
"name": "infoDisplay"
},
{
"name": "tooltip",
"align": "blabs",
"x": 0,
"y": 56
},
{
"name": "thumbnail"
},
{
"name": "controlBar",
"align": "blabs",
"x": 0,
"y": 0,
"children": [
{
"name": "progress",
"align": "blabs",
"x": 0,
"y": 44
},
{
"name": "playButton",
"align": "tl",
"x": 15,
"y": 12
},
{
"name": "timeDisplay",
"align": "tl",
"x": 10,
"y": 7
},
{
"name": "fullScreenButton",
"align": "tr",
"x": 10,
"y": 12
},
{
"name": "volume",
"align": "tr",
"x": 5,
"y": 10
}
]
}
]
})
that.currentTime = new Date().getTime()
if (localStorage.getItem('havePlay') && JSON.parse(localStorage.getItem('havePlay')).playerId !== that.$route.params.fileId) {
that.player.pause()
that.$message({
message: '您已经有正在播放的视屏,不能同时播放多个!',
type: 'warning'
});
} else if (!localStorage.getItem('havePlay')) {
const obj = {
playerId: that.$route.params.fileId,
havePlay: true,
currentTime: that.currentTime
}
localStorage.setItem('havePlay', JSON.stringify(obj))
}
var _beforeUnload_time = 0, _gap_time = 0;
window.onbeforeunload = function () {
_beforeUnload_time = new Date().getTime();
}
window.onunload = function () {
_gap_time = new Date().getTime() - _beforeUnload_time;
//浏览器关闭
if (_gap_time <= 5) {
window.localStorage.removeItem("havePlay");
}
}
//skinLayout设置只显示全屏和音量按钮
// 点击播放后调打点方法
//视频由暂停恢复为播放时触发。
that.player.on('completeSeek', function ({paramData}) {
that.haveSeek = true
that.playTime = paramData;
})
//视频由暂停恢复为播放时触发。
that.player.on('playing', function (e) {
that.playTime = that.player.getCurrentTime();
})
//视频销毁。
that.player.on('dispose', function (e) {
if (JSON.parse(localStorage.getItem('havePlay'))) {
window.localStorage.removeItem("havePlay");
}
that.clearIntervalFun();
})
},
destroyed() {
window.removeEventListener('beforeunload', e => this.beforeunloadHandler(e))
if (JSON.parse(localStorage.getItem('havePlay'))&& JSON.parse(localStorage.getItem('havePlay')).currentTime == this.currentTime) {
window.localStorage.removeItem("havePlay");
}
this.clearIntervalFun();
},
解释:
其中 JSON.parse(localStorage.getItem('havePlay')).currentTime 是用来判断是否是在当前播放页的,页面一进入先获取当前时间赋值给 播放页的 that.currentTime = new Date().getTime() ,如果是第一次进入播放页,则播放页的时间复制给标识中的时间,只要页面不刷新不关闭,俩一直一样,但如果是刷新了页面,则 播放页的 that.currentTime 会被重新赋值,但标识里的 currentTime 不会被重新赋值,所以用此来做判断当前点击刷新按钮时是否是在正在播放的视频页点击刷新的如果俩时间一样则清除标识,而如果是复制的 url 则俩时间不一样,点击刷新时不清除标识。
//清除定时器
clearIntervalFun() {
const that = this
if (that.intervalTime) {
clearInterval(that.intervalTime);
that.intervalTime = null;
}
},
//阻止F5刷新
stopF5Refresh() {
document.onkeydown = function (e) {
var evt = window.event || e;
var code = evt.keyCode || evt.which;
if (code == 116) {
if (evt.preventDefault) {
evt.preventDefault();
} else {
evt.keyCode = 0;
evt.returnValue = false
}
}
}
},
//浏览器刷新事件
beforeunloadHandler (e) {
if (JSON.parse(localStorage.getItem('havePlay'))&& JSON.parse(localStorage.getItem('havePlay')).currentTime == this.currentTime) {
window.localStorage.removeItem("havePlay");
}
},
vue禁止浏览器F5进行刷新和监听浏览器刷新事件的更多相关文章
- iOS微信浏览器回退不刷新(监听浏览器回退事件)
兼容性:兼容全部ios系统 $(function(){ pushHistory(); }); function pushHistory(){ window.addEventListener(" ...
- vue监听浏览器窗口大小变化
首先,页面初始化mounted的时候,通过 document.body.clientWidth 和 document.body.clientHeight 来获取到浏览器的宽和高,然后通过 window ...
- vue JS实现监听浏览器返回按键事件
// 这个是监听浏览器回退键的returnButton () { let vm = this; $(document).ready(function () { if (window.history & ...
- JS实时监听浏览器宽度的变化
boot:function(){ //加载页面时执行一次 changeMargin(); //监听浏览器宽度的改变 window.onresize = function(){ changeMargin ...
- js监听浏览器tab窗口切换
js监听浏览器tab窗口切换 ——IT唐伯虎 摘要:js监听浏览器tab窗口切换. if (document.hidden !== undefined) { document.addEventLis ...
- JS监听浏览器标签页的显示与隐藏
/** * 监听浏览器标签页的显示与隐藏 */ class ListenerPageVisibility { constructor () { // 设置隐藏属性和改变可见属性的事件的名称 this. ...
- 【hugo】- hugo 监听浏览器切换title
hugo 博客 监听浏览器title 动态改变浏览器title标题 找到head.html themes/maupassant/layouts/partials/head.html 添加监听js 可以 ...
- 监听浏览器tab切换
监听浏览器切屏 为了完成验证用户在切换浏览器tab时进行登录再次认证需求需要监听浏览器切换窗口 if (document.hidden !== undefined) { document.addEve ...
- React监听窗口变化事件
功能说明:本例子采用MUI table组件 + React实现. 需求描述:固定表头,列表高度随浏览器窗口的改变而改变.(本例中当窗口高度小于472像素后,便不作限制) 实现简介:1.监听浏览器窗口, ...
- js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写
js进阶 12-6 监听鼠标滚动事件和窗口改变事件怎么写 一.总结 一句话总结:滚动事件scroll(),浏览器窗口调整监听resize(),思考好监听对象. 1.滚动事件scroll()的监听对象是 ...
随机推荐
- (转)[Android测试] Android Studio+Appium+Java+Windows 自动化测试之二:Appium环境安装搭建
一.需要下载安装的东西 1. 文件下载 网上也有挺多安装教程的,这里我提供我的安装方法.Win10 64位.一些文件我在后面打包. 2016.9.12号本人安装记录. SDK: 由于我是搞Androi ...
- 青少年CTF平台-Web-Robots
题目信息 题目名称:Robots 题目描述:昨天十三年社团讲课,讲了Robots.txt的作用,小刚上课没有认真听课正在着急,你能不能帮帮忙? 题目难度:一颗星 解题过程 访问题目链接 在这里插入图片 ...
- [minio]简介与安装
简介 MinIO是一款高性能的分布式对象存储系统. 官网地址 特性 轻便 高性能 跨平台 高扩展性 云原生支持 兼容Amazon S3 基本概念 s3:simple storage service,简 ...
- cs50ai0----search
cs50ai0-------Search cs50ai0-------Search 基础知识 课后题目 代码实践 学习链接 总结 基础知识 (1) search problem 上图是搜索问题的一般形 ...
- Azure Data Factory(六)数据集类型为Dataverse的Link测试
一,引言 之前有讲过 Azure Data Factory 的 Copy Data 的操作,演示了将 Blob Storage1 的数据通过 Azure Data Factory 复制到 Blob S ...
- influxdb 函数 non_negative_derivative 使用
转载请注明出处: 在InfluxDB中,non_negative_derivative()函数用于计算指定字段的非负导数.它可以用来计算时间序列数据的速率或增长率. 该函数的语法如下: non_neg ...
- API接口获取快手商品详情(封装代码)
快手是中国最大的短视频平台之一,也是许多电商企业进行推广的重要渠道.为了更好地了解快手的商品信息,我们可以通过API接口来获取商品详情. 首先,我们需要了解快手API接口和相应的文档 接下来,我们需要 ...
- 图解Spark Graphx基于connectedComponents函数实现连通图底层原理
原创/朱季谦 第一次写这么长的graphx源码解读,还是比较晦涩,有较多不足之处,争取改进. 一.连通图说明 连通图是指图中的任意两个顶点之间都存在路径相连而组成的一个子图. 用一个图来说明,例如,下 ...
- Tongweb远程调试
最近,在对项目进行国产化时,要求springboot项目容器换成tongweb.在部署中,有个问题一直无法在本地重现,搜了下网上资料,基本没法实现,所以我整理了下.注意,项目包代码必须与本地代码保持一 ...
- 树莓派4b装系统到运行 Blazor Linux 本地程序全记录
在Linux下运行gui程序,咱也是第一次做,属于是瞎子过河乱摸一通,写得有什么不对和可以优化的地方,希望各位看官斧正斧正. 1. 下载烧录器 https://www.raspberrypi.com/ ...