Shanbay JK

在扇贝单词网页版上让 j 拥有 1 跟 d 的功能,k 拥有 2 的功能

目前为 2021-03-04 提交的版本。查看 最新版本

// ==UserScript==
// @name         Shanbay JK
// @namespace    https://github.com/willbchang/shanbay-jk
// @version      1.1
// @description  在扇贝单词网页版上让 j 拥有 1 跟 d 的功能,k 拥有 2 的功能
// @author       Will B Chang
// @match        https://web.shanbay.com/wordsweb/*
// @grant        GPL-3.0
// ==/UserScript==

(function () {
    'use strict';

    // 模拟点击事件
    function click(element) {
        const event = document.createEvent('Events');
        event.initEvent('click', true, false);
        element.dispatchEvent(event);
    }

    // 监听键盘按下去的事件
    document.addEventListener('keypress', ({key}) => {
        // 从页面上获取认识、不认识、下一个、撤销四个元素
        const know = document.querySelector('div[class*=index_green]')
        const dontKnow = document.querySelector('div[class*=index_red]')
        const next = document.querySelector('div[class*=StudyPage_nextBtn]')
        const undo = document.querySelector('div[class*=Message_message] div span')
        const isSpelling = document.getElementById('checkAnswer') !== null

        // 避免在输入单词时触发 next 的点击事件导致拼写无法完成
        // j: 如果按键是 j,然后页面上有 know 元素,则触发其点击事件,没有的话就触发 next 的点击事件
        // k: 同理
        if (isSpelling) return
        if (key === 'j') click(know || next)
        if (key === 'k') click(dontKnow || undo)
    })
})();

QingJ © 2025

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