[更新]智慧树刷课脚本(js)解放你的双手(1.5倍速率)

首页 / 源码 / 正文

智慧树

前言

  博主最近又选了智慧树网课,今天开始刷网课的时候发现原来写的脚本(智慧树刷课js脚本)失效了,原来的答题界面可以不选答案直接关闭,现在必须答题才能关闭,今天修改了一下,又可以愉快的开始刷课啦,这次修改了代码使用JQuery。


源代码(更新时间:2019-09-02)

/**
*  author: 雨落凋殇
*  blog website: https://rainss.cn
*  description: 自动播放、自动下一集、自动选择视频弹窗题目、自动关闭答题窗口、刷智慧树网课必备
*  use-method: 打开智慧树播放课程界面 按F12 -> Console -> 粘贴本代码 ->按回车键  
*  use-method: 视频左上方出现一个图标点击图标开始刷课 显示‘已开’脚本开始监听 再次点击图标关闭
*  upadteTime: 2019/04/03 21:36:00
*/
//查找节点
var tips = $(".exploreTip");
//创建新节点
var option = $("<div>");
//添加样式
var args = {
    "color":"DarkOrange",
    "text-align":"center",
    "line-height":"90px",
    "font-size":"30px",
    "background-image": "url()",
    "background-repeat": "no-repeat",
    "background-size": "100%",
    "width": "90px",
    "height": "90px",
    "border-radius": "45px",
    "position":"fixed",
    "left":"60px",
    "top":"200px", 
    "z-index":"999"
};
option.css(args);
//添加点击事件
option.attr("onClick","StartOrStop()");
option.attr("id","rains");
option.text("Rains");
//插入节点到页面
tips[0].parentNode.insertBefore(option[0],tips[0]);
//定时器
var timer;
//初始状态 0 开启 1关闭
var startstatus = 0;
//次数
var number = 0;
//视频播放到91%时候切换下一个
var percent = 91;
//函数
function start(){
    if(number % 200 == 0){
          console.clear();
    }
    number += 1;
    
    //如果一点五倍速率没有开启则开启
    var speed = $(".speedBox").css("background-image");
    if(speed.indexOf("1.5") == -1){
        $("div[rate='1.5']").click();
    }
    //判断音量
    var volume = $(".volumeBox.volumeNone")[0];
    if(volume == undefined){
        $(".volumeIcon").click();
    }
    //获取进度条
    var pass = $(".passTime");
    //获取答题框状态
    var dialog = $(".wrap_popboxes.wrap_popchapter")[0];
    
    //点击关闭按钮关闭答题框
    if(dialog != undefined){
        $("#tmDialog_iframe").contents().find("input[_correctanswer=1]")[0].click()
        //延时关闭弹窗
        setTimeout("$(\".popbtn_cancel\")[0].click();",1000)
    }
    //判断播放进度是否大于83%
    if(parseInt(pass[0].style.width) > percent){
        //切换下一个视频
        $("#nextBtn").click();
    }
    console.log("执行第"+ number + "次");
}
function StartOrStop(){
    //获取播放状态
    var play  = $(".bigPlayButton.pointer")[0];
    if (startstatus == 0){
        //开始脚本
        timer = setInterval(start, 3000);
        //已经暂停 点击开始按钮 
        if(play.style.display == "block"){
            play.click();
        }
        startstatus = 1;
        var rains = $("#rains");
        rains.text("已开");
        rains.css("color","blue");
        console.log("刷课开始执行");
    }else if (startstatus == 1) {
        //停止脚本
        clearInterval(timer);
        //已经播放 暂停播放
        if(play.style.display == "none"){
            play.click();
        }
        startstatus = 0;
        var rains = $("#rains");
        rains.text("已关");
        rains.css("color","red");
        console.log("刷课已停止");
    }
}
//执行监听方法 默认填入代码后开启脚本
StartOrStop();

使用方法

  打开智慧树平台,点开需要播放的课程视频 按F12选择最顶上的Console点击下面的 >后面的空白处,将本博客提供的js代码复制粘贴到空白处,按回车键后左侧视频上会出现带Rains字样的图标,图标显示“已开”,刷课脚本开始工作,再次点击图标显示“已关”,刷课脚本停止。如下图所示!
  
  智慧树刷课脚本使用演示

源代码下载(文件没有更新文件依然是1.0倍速率)

下载代码:智慧树刷课脚本.js

评论区
头像
    头像
    goooreee
      

    视频播放到下一p后页面会刷新 console被清空了怎么办

      头像
      @goooreee

      如果页面会被刷新那无解了,鉴于现在智慧树有学习习惯分,我都没有用脚本了。

        头像
        goooreee
          
        @雨落凋殇

        好的感谢感谢

    头像
    aiuzh
      

    弹窗问题解决不了,这是咋回事儿

      头像
      @aiuzh

      智慧树现在改版了。以前的有的地方特别是弹窗原来最多就多选和单选,但是现在多了一种一个弹窗上面有多个题目的情况。因为现在智慧树有学习习惯分,所以基本都是手动看了没有用这个了。

    头像
    南柒
      

    修改一下加上静音和1.5倍速就完美了

      头像
      @南柒

      1.5倍 静音已经加上,文件没有更新,复制文章中的代码就可以。

    头像
    南柒
      

    有点看不懂啊,大佬,不能1.5倍数啊

      头像
      @南柒

      可以改的

    头像
    南柒
      

    有点看不懂啊,大佬

    头像
    蛋蛋
      

    大佬,默默地问一下,能做一个河北云教育的刷课时的脚本吗

      头像
      @蛋蛋

      都没听过😁

    头像
    EchoCow
      

    我擦嘞,我刚写完。早半小时来看我就懒得写了 噗噗噗噗噗噗