您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Enables loop functionality for HTML5 videos with context menu toggle
- // ==UserScript==
- // @name Loop HTML5 Videos Toggle
- // @namespace StephenP
- // @version 1.0
- // @description Enables loop functionality for HTML5 videos with context menu toggle
- // @author StephenP
- // @match *://*/*
- // @grant GM_registerMenuCommand
- // @grant GM_unregisterMenuCommand
- // ==/UserScript==
- (function() {
- 'use strict';
- let isLoopingEnabled = false;
- GM_registerMenuCommand('▶️ Enable Loop',setLooping);
- // Variables to track the state of looping
- const videoElements = document.getElementsByTagName('VIDEO');
- function toggleVideoLoop(video) {
- if (!video.loop) {
- video.loop = true;
- video.removeEventListener('ended',vPause);
- video.addEventListener('ended',vPlay);
- } else {
- video.loop = false;
- video.removeEventListener('ended',vPlay);
- video.addEventListener('ended',vPause);
- }
- }
- // Toggle loop when clicking on videos
- function setLooping(){
- if(!isLoopingEnabled){
- GM_unregisterMenuCommand('▶️ Enable Loop')
- GM_registerMenuCommand('⏹️ Disable Loop',setLooping)
- isLoopingEnabled=true;
- }
- else{
- GM_unregisterMenuCommand('⏹️ Disable Loop')
- GM_registerMenuCommand('▶️ Enable Loop',setLooping)
- isLoopingEnabled=false;
- }
- for(let video of videoElements){
- toggleVideoLoop(video);
- }
- }
- function vPause(e){
- e.target.pause();
- }
- function vPlay(e){
- e.target.play();
- }
- })();