您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
grafana html decode
当前为
// ==UserScript== // @name grafana-html-decode // @namespace http://tampermonkey.net/ // @version 1.0 // @description grafana html decode // @author chong // @include *://*.otr-devops.cn.svc.corpintra.net/* // @icon  // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; // HTML解码函数 function decodeHTML(html) { var txt = document.createElement('textarea'); txt.innerHTML = html; return txt.value; } // 解码指定元素的内容 function decodeHTMLForElements(elements) { elements.forEach(element => { element.innerHTML = decodeHTML(element.innerHTML); }); } // 主解码逻辑 function decodeAll() { // 解码所有具有特定类名的元素 const messageElements = document.querySelectorAll('.css-uev0p3-logs-row__message'); decodeHTMLForElements(messageElements); // 解码所有表格单元格内容 const tableCells = document.querySelectorAll('.css-xdnfhu-logs-row-details-table'); decodeHTMLForElements(tableCells); console.log('解码完成!'); } // 动态添加解码按钮 function addDecodeButton() { // 选择所有符合条件的 <button> 元素 const targetButton = document.querySelector('.button-group.css-8qah51.refresh-picker'); // 检查是否已经添加过按钮 if (!targetButton.nextElementSibling || !targetButton.nextElementSibling.classList.contains('custom-decode-button')) { // 创建新的按钮 const decodeButton = document.createElement('button'); decodeButton.className = 'custom-decode-button css-rf9bj2-toolbar-button '; decodeButton.innerText = 'Decode'; decodeButton.title = 'Decode HTML entities'; decodeButton.onclick = decodeAll; // 设置按钮的其他样式 decodeButton.style.marginLeft = '3px'; decodeButton.style.textAlign = 'center'; decodeButton.style.width = '96px'; // 将按钮插入到目标按钮的右边 targetButton.parentElement.appendChild(decodeButton); } } // 延迟1000毫秒后执行addDecodeButton函数 setTimeout(addDecodeButton, 1000); })();