您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Adds buttons to each input to show/hide passwords
// ==UserScript== // @name Password Toggler - view input passwords // @namespace https://github.com/pckltr/password-toggler // @version 1.4 // @description Adds buttons to each input to show/hide passwords // @author pckltr // @match *://*/* // ==/UserScript== (function () { "use strict"; const showIcon = ""; const hideIcon = ""; const buttonStyle = ` .password-toggler-button-parent { position: relative; overflow: visible; } .password-toggler-button { position: absolute; top: 50%; right: 8px; transform: translateY(-50%); cursor: pointer; background-repeat: no-repeat; z-index: 9999; background-color: #dcdcdc; border-radius: 50%; background-position: center; width: 20px; height: 20px; display: none; } .password-toggler-show { background-image: url(${showIcon}); } .password-toggler-hide { background-image: url(${hideIcon}); } `; // append styles to the document const styleElement = document.createElement("style"); styleElement.appendChild(document.createTextNode(buttonStyle)); document.head.appendChild(styleElement); // create toggle button const createToggleButton = (input) => { const button = document.createElement("div"); button.className = "password-toggler-button password-toggler-show"; button.title = "Show password - Password Toggler"; button.addEventListener("click", () => togglePassword(input, button)); input.parentElement.classList.add("password-toggler-button-parent"); input.parentElement.appendChild(button); }; // toggle visibility const togglePassword = (input, button) => { const isPassword = input.type === "password"; input.type = isPassword ? "text" : "password"; button.className = "password-toggler-button " + (isPassword ? "password-toggler-hide" : "password-toggler-show"); button.title = (isPassword ? "Hide password" : "Show password") + " - Password Toggler"; }; // add buttons const addToggleButtons = () => { document.querySelectorAll("input[type='password']").forEach((input) => { const button = input.parentElement.querySelector( ".password-toggler-button" ); if (!button) { createToggleButton(input); } else { input.addEventListener("focus", () => { button.style.display = "inline"; }); input.addEventListener("blur", () => { if (!input.value) { button.style.display = "none"; } }); } }); }; // handle dynamically added password fields const observer = new MutationObserver(addToggleButtons); observer.observe(document.body, { childList: true, subtree: true }); // initial run addToggleButtons(); })();
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址