通常在网络视频课程学习时,获得学习积分有两类:

第一类: 通过用户心跳检测用户是否在线,同时服务器端根据在线时长与其它逻辑积分。
(这种方案在客户端是无论如何也快不了的,只能老老实实消耗相应的时间)

第二类: 通过看完视频(发出ended事件)、视频播放时间达到临近结尾时、视频播放经过事先设定的几个时间锚点时等逻辑来触发得到积分(本贴仅讨论这类)。
争对这类触发方式,用以下三行代码来分别对应:

1. 直接发送视频观看完成事件(当前的*假期*研修就是这种方式):

document.querySelector("video").dispatchEvent(new Event("ended"))
javascript:var v=document.querySelector("video");if(v){v.muted=true;v.playbackRate=1.2; v.play();}

2. 直接设置视频播放到结尾(人力资源网有一类视频就是这种):

var v=document.querySelector("video");
if(v){
    v.muted=true;
    v.currentTime=Math.floor(v.duration);
    v.play();
}

3. 高倍速播放(必须经过几个时间锚点,学习公社上有一些视频是这种)【插件市场上已经有很多倍速播放视频的插件,可直接安装使用】:

var v=document.querySelector("video");
if(v){
  v.muted=true;
  v.playbackRate=16;//0.1-16任意设置
  v.play();
}

4. 其实还有一种就是通过控制台的网络面板,编辑并重播请求(EDGE中是这样的称呼),修改相应的参数再提交一次。【这种比较危险,不建议使用】

以上js代码如何运行?

1 写成浏览器插件,这个需要有一定的js知识并阅读浏览器插件写作规范,相对新手不太友好,但它可以实现批量自动化,全程无需人肉干预。
2 粘贴代码到油猴插件中运行,也比较繁琐,个人不推荐。
3 直接在浏览器中运行【强烈推荐】。

运行方法如下(以第一种方案的代码为例,其它方案只是要运行的代码不同):

(1) 在观看视频的页面地址栏输入【适用于临时执行一次】

javascript: document.querySelector("video").dispatchEvent(new Event("ended"))

【注意javascript:】这个单词和冒号在地址栏是不能粘贴的,只能手动输入

(2) 把代码添加到收藏夹中,要运行时就点击一下【适用于反复执行】。

(3) 也可以在观看视频的页面按F12打开浏览器的控制台,选择Console(控制台)在 > 后面输入然后回车【适用于执行多行或者需要查看返回信息的情况】

document.querySelector("video").dispatchEvent(new Event("ended"))

PS:如果出现完成,但学时没有增加的情况,请做如下尝试。

先按F12,在控制台输入

document.querySelector("video").dispatchEvent(new Event("ended"))

把视频完成,点击播放,暂停,再播放。
此时视频显示完成,但是学时没有增加。
再输入

var v=document.querySelector("video");
if(v){
    v.muted=true;
    v.currentTime=Math.floor(v.duration);
    v.play();
}

再出去看,就会发现学时增加了。

End
最后修改:2024 年 07 月 22 日
请随意赞赏