Greasy Fork is available in English.

开源阅读web端快捷键

开源阅读web服务添加wasd快捷键支持

// ==UserScript==
// @name         开源阅读web端快捷键
// @namespace    http://tampermonkey.net/
// @version      0.5
// @description  开源阅读web服务添加wasd快捷键支持
// @author       coccvo
// @match        http://*/vue/index.html
// @icon         
// @grant        none
// @license MIT
// ==/UserScript==


(function() {
    'use strict';

    const SCROLL_FRACTION = 0.9; // 设置滚动距离为视口高度的百分比

    document.addEventListener('keydown', function(e) {
        // 定义一个数组包含需要处理的按键
        const keysToHandle = ['ArrowUp', 'ArrowDown', 'w', 's'];

        // 检查按键是否在需要处理的列表中
        if (keysToHandle.includes(e.key)) {
            // 计算滚动距离
            let distance = e.key === 'ArrowDown' || e.key === 's' ? window.innerHeight * SCROLL_FRACTION : -window.innerHeight * SCROLL_FRACTION;

            // 执行平滑滚动
            if ('scrollBehavior' in document.documentElement.style) {
                window.scrollBy({
                    top: distance,
                    left: 0,
                    behavior: 'smooth'
                });
            } else {
                window.scrollBy(0, distance);
            }

            // 阻止按键的默认行为,以允许脚本完全控制滚动(这将改变上下箭头的默认滚动行为)
            e.preventDefault();
        }
    }, false);

// 等待页面加载完成
window.addEventListener('load', function() {
    // 上次点击时间的标志位
    var lastClickTime = 0;
    // 设置冷却时间(以毫秒为单位)
    var cooldown = 500;

    document.addEventListener('keydown', function(event) {
        // 获取按键代码
        var keyCode = event.keyCode || event.which;

        // 查找包含特定图标的元素
        function findElementByIcon(icon) {
            var elements = document.querySelectorAll('div.tool-icon .iconfont');
            for (var i = 0; i < elements.length; i++) {
                if (elements[i].textContent.includes(icon)) {
                    return elements[i].parentElement; // 返回父元素以触发点击事件
                }
            }
            return null;
        }

        // 模拟点击 content 元素
        function clickContent() {
            var contentDiv = document.querySelector('div.content[data-v-9a75e165]');
            if (contentDiv) {
                contentDiv.click();
            }
        }

        // 获取当前时间
        var now = Date.now();

        // 检查是否按下了 'a' 键或 'd' 键,并且距离上次点击时间大于冷却时间
        if (keyCode === 65 && now - lastClickTime > cooldown) { // 'a' 键
            var prevChapter = findElementByIcon(''); // 使用特定图标
            if (prevChapter) {
                prevChapter.click();
                lastClickTime = now; // 更新上次点击时间
                clickContent(); // 执行一次 content 点击
            }
        } else if (keyCode === 68 && now - lastClickTime > cooldown) { // 'd' 键
            var nextChapter = findElementByIcon(''); // 使用特定图标
            if (nextChapter) {
                nextChapter.click();
                lastClickTime = now; // 更新上次点击时间
                clickContent(); // 执行一次 content 点击
            }
        }
    });
}, false);


})();