雨课堂刷课脚本

只针对雨课堂视频进行自动播放,点击左侧边栏的开始刷课即可自动刷课,刷课期间请勿跳转页面!!!

目前為 2023-05-25 提交的版本,檢視 最新版本

// ==UserScript==
// @name         雨课堂刷课脚本
// @namespace    http://tampermonkey.net/
// @version      0.1.4
// @description  只针对雨课堂视频进行自动播放,点击左侧边栏的开始刷课即可自动刷课,刷课期间请勿跳转页面!!!
// @author       风之子
// @license      MIT
// @match        https://www.yuketang.cn/*
// @icon         http://newqi.cn/images/logo128.ico
// @grant        GM_addStyle
// ==/UserScript==
// 雨课堂刷课脚本
let shuake = {};

shuake.shuake = function () {
  // 用于判断不同的课程
  let baseUrl = location.href;
  // 根据客户端记录的URL判别刷到那一集了,不影响第一批用户的刷课进度。
  if (localStorage.getItem('classIndex')) {
    localStorage.setItem(baseUrl, +localStorage.getItem('classIndex'));
    localStorage.removeItem('classIndex');
  }
  let count = +localStorage.getItem(baseUrl) || 0;
  let classList = [];
  // 用于标记视频是否播放完毕
  let play = true;

  try {
    main();
  } catch (error) {
    console.log(error);
  }


  function main() {
    autoSlide(count).then(() => {

      let list = document.querySelector('.logs-list').childNodes;
      console.log('刷课状态:第' + (count + 1) + '个/' + list.length + '个');
      classList[count] = list[count].querySelector('.content-box').querySelector('section');
      let classInfo = classList[count].querySelector('.tag').querySelector('use').getAttribute('xlink:href');
      // 视频处理
      if (classInfo.includes('shipin') && play === true) {
        play = false;
        classList[count].click();
        setTimeout(() => {
          const video = document.querySelector('video');
          console.log('第' + (count + 1) + '个:进入了视频区');
          let currentTime = Date.now();
          let timer1 = setInterval(() => {
            // console.log('已播放时间:' + (Date.now() - currentTime) / 1000 + 's  视频时长:' + video.duration + 's');
            if (Date.now() - currentTime >= (video.duration + 40) * 1000) {
              count++;
              localStorage.setItem(baseUrl, count);
              play = true;
              history.back();
              main();
              clearInterval(timer1);
            }
          }, 10000);
        }, 3000)
        // 批量处理
      } else if (classInfo.includes('piliang') && play === true) {
        let zhankai = classList[count].querySelector('.sub-info').querySelector('.gray').querySelector('span');
        sync();
        async function sync() {
          await zhankai.click();
          setTimeout(() => {
            console.log(list[count]);
            // 保存所有视频
            let a = list[count].querySelector('.leaf_list__wrap').querySelectorAll('.activity__wrap');
            console.log(a);
            let count1 = 0;
            bofang();
            function bofang() {
              let classInfo1 = a[count1]?.querySelector('.tag').querySelector('use').getAttribute('xlink:href');
              let play = true;
              console.log(count1);
              console.log(a.length);
              if (classInfo1?.includes('shipin') && play === true) {
                play = false;
                a[count1].click();
                console.log('开始播放视频');
                let timer = setInterval(() => {
                  let progress = document.querySelector('.progress-wrap').querySelector('.text');
                  if (progress.innerHTML.includes('100%')) {
                    count1++;
                    clearInterval(timer);
                    history.back();
                    setTimeout(() => {
                      bofang();
                    }, 2000);
                  }
                }, 3000)
              } else if (classInfo1 && !classInfo1.includes('shipin') && play === true) {
                console.log('不是视频');
                count1++;
                bofang();
              } else if (count1 === a.length && play === true) {
                console.log('合集播放完毕');
                count++;
                localStorage.setItem(baseUrl, count);
                main();
              }
            }
          }, 2000)
        }
      } else if (count == list.length && play === true) {
        document.querySelector('.myli').innerHTML = '<span>刷完了~</span>';
        return;
      } else if (!(classInfo.includes('shipin') || classInfo.includes('piliang')) && play === true) {
        console.log('第' + (count + 1) + '个:不是视频,已跳过');
        count++;
        localStorage.setItem(baseUrl, count);
        main();
      }

    })
  }
  // 根据视频集数,自动下拉刷新集数
  async function autoSlide(count) {
    let frequency = parseInt((count + 1) / 20) + 1;
    for (let i = 0; i < frequency; i++) {
      await new Promise((resolve, reject) => {
        setTimeout(() => {
          document.querySelector('.viewContainer').scrollTop = document.querySelector('.el-tab-pane').scrollHeight;
          resolve();
        }, 1000)
      })
    }
  }
}



shuake.addButton = function () {
  let ul = document.querySelector('.left__menu').querySelector('.top').querySelector('ul');
  let li = document.createElement('li');
  li.classList.add('myli');
  li.innerHTML = '<span>开始刷课</span>';
  ul.appendChild(li);
  li.addEventListener('click', function () {
    shuake.shuake();
    li.innerHTML = '<span>刷课中~</span>';
    li.classList.add('active');
  })
}




// 主程序
shuake.main = function () {
  shuake.addButton();
};




// 添加css样式
function addStyle() {
  let css = `
    .myli{
      height:50px;
      line-height:50px;
    }
    .myli:hover{
      background:yellow;
      color:#000;
      cursor:pointer;
    }
    .active{
      background:#1c223b;
      color:#fff;
    }
  `;
  GM_addStyle(css);
}



(function () {
  'use strict';
  shuake.main();
  addStyle();
})()

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址