🎉 欢迎访问GreasyFork.Org 镜像站!本镜像站由公众号【爱吃馍】搭建,用于分享脚本。联系邮箱📮

Greasy fork 爱吃馍镜像

Greasy Fork is available in English.

📂 缓存分发状态(共享加速已生效)
🕒 页面同步时间:2025/12/27 12:46:57
🔄 下次更新时间:2025/12/27 13:46:57
手动刷新缓存

UnURLencode

Decode percent-encoded text on visited web pages

이 스크립트를 설치하려면 Tampermonkey, Greasemonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

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

이 스크립트를 설치하려면 Tampermonkey 또는 Violentmonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey 또는 Userscripts와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 Tampermonkey와 같은 확장 프로그램이 필요합니다.

이 스크립트를 설치하려면 유저 스크립트 관리자 확장 프로그램이 필요합니다.

(이미 유저 스크립트 관리자가 설치되어 있습니다. 설치를 진행합니다!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 Stylus와 같은 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

이 스타일을 설치하려면 유저 스타일 관리자 확장 프로그램이 필요합니다.

(이미 유저 스타일 관리자가 설치되어 있습니다. 설치를 진행합니다!)

🚀 安装遇到问题?关注公众号获取帮助

公众号二维码

扫码关注【爱吃馍】

回复【脚本】获取最新教程和防失联地址

// ==UserScript==
// @name         UnURLencode
// @namespace    lainscripts_unurlencode
// @version      0.2
// @description  Decode percent-encoded text on visited web pages
// @author       lainverse
// @match        *://*/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';
    let pctdetect = /%[0-9A-F][0-9A-F]/,
        pctmatch = /(%[0-9A-F][0-9A-F])+/g;
    function crawler(node) {
        switch (node.nodeType) {
            case Node.ELEMENT_NODE:
                for (let child of node.childNodes) {
                    if (pctdetect.test(child.textContent)) {
                        crawler(child);
                    }
                }
                break;
            case Node.TEXT_NODE:
                node.nodeValue = node.nodeValue.replace(pctmatch, function(match){
                    try {
                        return decodeURIComponent(match);
                    } catch(ignore) {
                        return match;
                    }
                });
        }
    }
    crawler(document.documentElement);

    let o = new MutationObserver(function(mutations) {
        let mutation, node;
        for (mutation of mutations) {
            for (node of mutation.addedNodes) {
                crawler(node);
            }
        }
    });
    o.observe(document.documentElement, {
        childList: true,
        characterData: true,
        subtree: true
    });
})();