点击时显示文字

用于在每次点击鼠标时漂浮文字,原名《社会主义核心价值观 - 点击时提醒》

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         点击时显示文字
// @namespace    https://gitee.com/codyme/
// @version      2.1
// @description  用于在每次点击鼠标时漂浮文字,原名《社会主义核心价值观 - 点击时提醒》
// @author       Cody
// @include      http://*
// @include      https://*
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @grant        GM_addValueChangeListener
// @grant        GM_registerMenuCommand
// @run-at       document-idle
// @license      MIT
// ==/UserScript==

(function () {
    'use strict';

    // 默认词典
    // 富强, 民主, 文明, 和谐, 自由, 平等, 公正, 法治, 爱国, 敬业, 诚信, 友善
    var DEFAULT_WORDS = ["\u5bcc\u5f3a", "\u6c11\u4e3b", "\u6587\u660e", "\u548c\u8c10", "\u81ea\u7531", "\u5e73\u7b49", "\u516c\u6b63", "\u6cd5\u6cbb", "\u7231\u56fd", "\u656c\u4e1a", "\u8bda\u4fe1", "\u53cb\u5584"];

    // 获取自定义的词典
    function updateWords() {
        try {
            var wordsStr = GM_getValue('words');
            if (!wordsStr) { } else {
                var temp = JSON.parse(wordsStr);
                if (Array.isArray(temp) && temp.length > 0) {
                    words = temp;
                }
            }
        } catch (error) {
            // 当解析失败时删除当前存储的词典
            GM_deleteValue('words');
        }
    }

    function openSettings() {
        var wordsText = window.prompt("\u8bf7\u8f93\u5165\u65b0\u7684\u8bcd\u5e93\uff1a\uff08\u5355\u8bcd\u95f4\u4f7f\u7528\u82f1\u6587\u9017\u53f7\u5206\u9694\uff09", words.join(","));
        // 输入内容为空时,还原默认词典
        if (!wordsText) {
            window.alert("\u8f93\u5165\u5185\u5bb9\u4e3a\u7a7a\uff0c\u5df2\u8fd8\u539f\u9ed8\u8ba4\u8bcd\u5178");
            words = DEFAULT_WORDS;
            // 因为 delete 方法不会触发 change 事件,需要额外调用一次set方法
            GM_setValue('words', null);
            GM_deleteValue('words');
            return;
        }
        var temp = wordsText.split(/\s*,\s*/);
        // 移除为空的单词
        for (var i = temp.length - 1; i >= 0; i--) {
            if (!temp[i]) {
                temp.splice(i, 1);
            }
        }
        // 没有有效的单词时,不做任何修改
        if (temp.length <= 0) {
            window.alert("\u5fc5\u987b\u5305\u542b\u81f3\u5c11\u4e00\u4e2a\u5355\u8bcd\uff0c\u8bf7\u91cd\u8bd5");
            return;
        }
        words = temp;
        // 保存新的词典
        GM_setValue('words', JSON.stringify(temp));
    }

    var words = DEFAULT_WORDS,
        index = Math.floor(Math.random() * words.length);

    updateWords();

    document.body.addEventListener('click', function (e) {
        // 点击对象是链接时跳过
        if (e.target.tagName == 'A') {
            return;
        }
        var x = e.pageX,
            y = e.pageY,
            span = document.createElement('span');
        span.textContent = words[index];
        index = (index + 1) % words.length;
        // 文字初始样式
        span.style.cssText =
            `z-index: 9999999;
            position: absolute;
            font-size: 14px;
            font-weight: bold;
            color: #dd2222;
            top: ${y - 20}px;
            left: ${x}px;
            transition: all 1.5s linear;
            pointer-events: none;'`;
        document.body.appendChild(span);
        setTimeout(function () {
            // 动画结束时样式
            span.style.top = y - 200 + 'px';
            span.style.opacity = 0;
            // 倒计时 1.5 秒后移除文字
            setTimeout(function () {
                span.parentNode.removeChild(span);
            }, 1500);
        }, 0);
    });

    GM_addValueChangeListener('words', function (name, old_value, new_value, remote) {
        // 来自当前标签页的 change 事件已经被 settings 方法处理了,这里只需要处理来自其他标签页的 change 事件
        if (remote) {
            words = DEFAULT_WORDS;
            updateWords();
        }
    });

    // 添加设置菜单项
    GM_registerMenuCommand("\u81ea\u5b9a\u4e49\u8bcd\u5178", openSettings, 'W');
})();