本帖最后由 yushangwl 于 2020-4-16 00:11 编辑
近期选课太多了,一个个看太麻烦,于是写了这段代码。之前我写的是js代码用在浏览器console控制台的。但是由于那些代码写的早了,早就失效了,我看到论坛之前也有人发过基于我的代码的修改版本,但是早就失效了。现在我重新弄了一个tampermonkey版本的出来供大家参考。console控制台版本的当然也有提供。
自动答题就是走一个形式,智慧树并不会用来算分数,本脚本多选题可能会选错,请悉知。由于智慧树有学习习惯分,一次刷完所有课程将没有学习习惯分,请注意。
tampermonkey版本的代码如下:
[JavaScript] 纯文本查看 复制代码 // ==UserScript==
// @name 知到智慧树刷课
// @namespace rainerosion
// @version 1.3.2
// @description 智慧树刷课脚本 自动静音 自动1.25倍播放 自动答题(智慧树视频弹出的题目随便选择没事)
// @author rainerosion
// @match *://studyh5.zhihuishu.com/videoStudy.html*
// @require https://base1.zhihuishu.com/able-commons/resources/uploader/client/js/jquery/jquery-1.7.2.min.js
// @grant unsafeWindow
// @license GPL3.0
// @supportURL https://github.com/rainerosion/zhihuishu
// ==/UserScript==
(function($) {
//监听点击事件
$("html").on("click","#rains", function () {
StartOrStop();
});
$.noConflict(true);
//定时器
var timer;
//++++++++ 以下为可设置的参数 ++++++++++
//初始状态 0 开启 1关闭
var startstatus = 0;
//次数
var number = 0;
//视频播放到91%时候切换下一个
var percent = 91;
//速率
var speed = "1.25";
//静音
var vol = true;
//答题?不答题将会移除答题框
var answer = true;
//++++++++ 可设置的参数结束 ++++++++++
//查找节点
var tips = $("body");
console.log(tips[0])
//创建新节点
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("id","rains");
option.text("Rains");
//插入节点到页面
tips[0].parentNode.insertBefore(option[0],tips[0]);
//函数
function start(){
if(number % 20 == 0){
console.clear();
}
number += 1;
//获取视频速率
var speedSpan = $(".speedBox>span").text().replace("X ","");
if(speedSpan != speed){
switch(speed){
case "1.0":
$("div[rate='1.0']").click();
break;
case "1.25":
$("div[rate='1.25']").click();
break;
case "1.5":
$("div[rate='1.5']").click();
break;
}
}
//判断音量
var volume = parseInt($(".volumeBox .passVolume")[0].style.height);
if(volume > 0 && vol == true){
$(".volumeIcon").click();
}
//获取进度条
var pass = $(".passTime");
//获取答题框状态
var dialog = $(".el-dialog__wrapper.dialog-test")[0];
if(dialog != undefined){
if(answer == false){
//移除答题框
$(".v-modal").remove();
$(".el-dialog__wrapper.dialog-test")[0].remove();
$("body").removeClass("el-popup-parent--hidden");
}else{
//如果是单选题或者判断题选择一个答案否则移除答题框
if($(".title-tit").text() == "【单选题】" || $(".title-tit").text() == "【判断题】"|| $(".title-tit").text() == "【多选题】"){
//选择选项的第一个用于获取正确答案
let list = $(".topic-list .topic-option-item");
list[0].click();
//取消已经选择的
list.each(function(){
if($(this).hasClass("active")){
$(this).click();
}
})
//选择答案
let answer = $(".answer span").text().split(",");
for(let i in answer){
let option = answer[i].charCodeAt() - 65;
$(".topic-list .topic-option-item")[option].click();
}
//延时关闭弹窗
setTimeout("$(\".el-dialog__wrapper.dialog-test .el-dialog__footer .dialog-footer .btn\")[0].click();",1000);
}else{
//如果不是这3个选项移除答题框以后弹框将不会出现
$(".v-modal").remove();
$(".el-dialog__wrapper.dialog-test")[0].remove();
$("body").removeClass("el-popup-parent--hidden");
}
}
let play = $(".bigPlayButton.pointer")[0];
//如果暂停继续播放
if(play.style.display == "block"){
play.click();
}
}else{
let play = $(".bigPlayButton.pointer")[0];
//如果暂停继续播放
if(play.style.display == "block"){
play.click();
}
}
//判断播放进度是否大于83%
if(parseInt(pass[0].style.width) > percent){
//切换下一个视频
$("#nextBtn").click();
}
console.log("执行第"+ number + "次");
}
function StartOrStop(){
var rains = $("#rains");
//获取播放状态
var play = $(".bigPlayButton.pointer")[0];
if (startstatus == 0){
//开始脚本
timer = setInterval(start, 3000);
//已经暂停 点击开始按钮 block时视频播放暂停
startstatus = 1;
rains.text("已开");
rains.css("color","blue");
console.log("刷课开始执行");
if(play.style.display == "block"){
play.click();
}
}else if (startstatus == 1) {
//停止脚本
clearInterval(timer);
//已经播放 暂停播放
startstatus = 0;
rains.text("已关");
rains.css("color","red");
console.log("刷课已停止");
if(play.style.display == "none"){
play.click();
}
}
}
//执行监听方法 默认填入代码后开启脚本
StartOrStop();
})(jQuery);
浏览器Console运行版本的代码如下
[JavaScript] 纯文本查看 复制代码 /**
* author: 雨落凋殇
* description: 自动播放、自动下一集、自动选择视频弹窗题目、自动关闭答题窗口、刷智慧树网课必备
* use-method: 打开智慧树播放课程界面 按F12 -> Console -> 粘贴本代码 ->按回车键
* use-method: 视频左上方出现一个图标点击图标开始刷课 显示‘已开’脚本开始监听 再次点击图标关闭
* upadteTime: 2019/04/03 21:36:00
*/
//定时器
var timer;
//++++++++ 以下为可设置的参数 ++++++++++
//初始状态 0 开启 1关闭
var startstatus = 0;
//次数
var number = 0;
//视频播放到91%时候切换下一个
var percent = 91;
//速率
var speed = "1.25";
//静音
var vol = true;
//答题?不答题将会移除答题框
var answer = true;
//++++++++ 可设置的参数结束 ++++++++++
//查找节点
var tips = $(".video-study");
//创建新节点
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]);
//函数
function start(){
if(number % 200 == 0){
console.clear();
}
number += 1;
//获取视频速率
var speedSpan = $(".speedBox>span").text().replace("X ","");
if(speedSpan != speed){
switch(speed){
case "1.0":
$("div[rate='1.0']").click();
break;
case "1.25":
$("div[rate='1.25']").click();
break;
case "1.5":
$("div[rate='1.5']").click();
break;
}
}
//判断音量
var volume = parseInt($(".volumeBox .passVolume")[0].style.height);
if(volume > 0 && vol == true){
$(".volumeIcon").click();
}
//获取进度条
var pass = $(".passTime");
//获取答题框状态
var dialog = $(".el-dialog__wrapper.dialog-test")[0];
if(dialog != undefined){
if(answer == false){
//移除答题框
$(".v-modal").remove();
$(".el-dialog__wrapper.dialog-test")[0].remove();
$("body").removeClass("el-popup-parent--hidden");
}else{
//如果是单选题或者判断题选择一个答案否则移除答题框
if($(".title-tit").text() == "【单选题】" || $(".title-tit").text() == "【判断题】"|| $(".title-tit").text() == "【多选题】"){
//选择选项的第一个用于获取正确答案
$(".topic-list .topic-option-item")[0].click();
//取消已经选择的
$(".topic-list .topic-option-item").each(function(){
if($(this).hasClass("active")){
$(this).click();
}
})
//选择答案
let answer = $(".answer span").text().split(",");
$.each(answer,function(index,value){
let option = value.charCodeAt() - 65;
$(".topic-list .topic-option-item")[option].click();
});
//延时关闭弹窗
setTimeout("$(\".el-dialog__wrapper.dialog-test .el-dialog__footer .dialog-footer .btn\")[0].click();",1000);
}else{
//如果不是这3个选项移除答题框以后弹框将不会出现
$(".v-modal").remove();
$(".el-dialog__wrapper.dialog-test")[0].remove();
$("body").removeClass("el-popup-parent--hidden");
}
}
let play = $(".bigPlayButton.pointer")[0];
//如果暂停继续播放
if(play.style.display == "block"){
play.click();
}
}else{
let play = $(".bigPlayButton.pointer")[0];
//如果暂停继续播放
if(play.style.display == "block"){
play.click();
}
}
//判断播放进度是否大于83%
if(parseInt(pass[0].style.width) > percent){
//切换下一个视频
$("#nextBtn").click();
}
console.log("执行第"+ number + "次");
}
function StartOrStop(){
var rains = $("#rains");
//获取播放状态
var play = $(".bigPlayButton.pointer")[0];
if (startstatus == 0){
//开始脚本
timer = setInterval(start, 3000);
//已经暂停 点击开始按钮 block时视频播放暂停
if(play.style.display == "block"){
play.click();
}
startstatus = 1;
rains.text("已开");
rains.css("color","blue");
console.log("刷课开始执行");
}else if (startstatus == 1) {
//停止脚本
clearInterval(timer);
//已经播放 暂停播放
if(play.style.display == "none"){
play.click();
}
startstatus = 0;
rains.text("已关");
rains.css("color","red");
console.log("刷课已停止");
}
}
//执行监听方法 默认填入代码后开启脚本
StartOrStop();
使用方法一:Tampermonkey脚本使用方法
使用方法二:浏览器console运行方法
如果本代码帮助到了你,请给我一个免费的评分吧,谢谢!
|