BiliBili-跳过互动视频

列表播放的时候,互动视频无法播放,而且还有33魔性的声音提示“互动视频需要在手机上观看”,这个脚本可以跳过互动视频,直接播放下一个视频。

  1. // ==UserScript==
  2. // @name BiliBili-PassInteractiveVideo
  3. // @name:zh-CN BiliBili-跳过互动视频
  4. // @namespace https://github.com/TitanRGB
  5. // @version 1.1
  6. // @description 列表播放的时候,互动视频无法播放,而且还有33魔性的声音提示“互动视频需要在手机上观看”,这个脚本可以跳过互动视频,直接播放下一个视频。
  7. // @description:zh-CN 列表播放的时候,互动视频无法播放,而且还有33魔性的声音提示“互动视频需要在手机上观看”,这个脚本可以跳过互动视频,直接播放下一个视频。
  8. // @author https://github.com/TitanRGB
  9. // @icon 
  10. // @match http*://bilibili.com
  11. // @match http*://bilibili.com/*
  12. // @match http*://www.bilibili.com
  13. // @match http*://www.bilibili.com/*
  14. // @license MPL-2.0
  15. // @license^ Mozilla Public License 2.0
  16. // @grant unsafeWindow
  17. // @charset UTF-8
  18. // @homepageURL https://github.com/SynRGB/BiliBili-PassInteractiveVideo
  19. // @contributionURL https://github.com/SynRGB/BiliBili-PassInteractiveVideo
  20. // @copyright Copyright © 2022-PRESENT, TitanRGB (https://github.com/TitanRGB)
  21. // ==/UserScript==
  22.  
  23. let last_run_time = new Date().getTime();
  24.  
  25. let main = function () {
  26. let tagDiv = document.getElementsByClassName("s_tag report-wrap-module report-scroll-module")[0].childNodes[0];
  27. // 鲁棒性+114
  28. if (tagDiv === null) {
  29. tagDiv = document.getElementsByClassName("tag-area clearfix")[0];
  30. }
  31. if (tagDiv !== null) {
  32. let tags = tagDiv.querySelectorAll("div[class='tag-item']");
  33. for (let i = 0; i < tags.length; i++) {
  34. if (tags[i].querySelector("span") !== null) {
  35. if (tags[i].querySelector("span").innerText === "互动视频") {
  36. let current_video = document.getElementsByClassName("player-auxiliary-playlist-item player-auxiliary-playlist-item-active player-auxiliary-playlist-item-showp")[0];
  37. if (current_video !== null) {
  38. let next_video = current_video.nextElementSibling;
  39. if (next_video !== null) {
  40. next_video.querySelector("div[class='player-auxiliary-playlist-item-title']").click();
  41. console.log("%c跳过互动视频 \n by JS script BiliBili-PassInteractiveVideo\n BiliBili-跳过互动视频", "color: #AAAAAA");
  42. // console.log(last_run_time);
  43. }
  44. }
  45. }
  46. }
  47. }
  48. }
  49. last_run_time = new Date().getTime();
  50. }
  51.  
  52. // if DOM changed, re-run the script
  53. let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
  54. let observer = new MutationObserver(function (mutations) {
  55. mutations.forEach(function () {
  56. // 通过增加时间间隔来避免无限回调
  57. if (new Date().getTime() - last_run_time > 500) {
  58. try {
  59. main();
  60. } catch (e) {
  61. // console.log("%cBiliBili-PassInteractiveVideo: " + e, "color: #AAAAAA");
  62. }
  63. }
  64. });
  65. });
  66. observer.observe(document.body, {
  67. childList: true,
  68. subtree: true
  69. });
  70.  
  71. console.log("JS script BiliBili-PassInteractiveVideo (BiliBili-跳过互动视频) loaded. See more details at https://github.com/SynRGB/BiliBili-PassInteractiveVideo");

QingJ © 2025

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