NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Jandan Treehole User Blocker // @namespace http://tampermonkey.net/ // @version 0.1 // @description 屏蔽煎蛋树洞页面中指定用户(登录和匿名)的完整帖子,包括用户名、内容和功能区域 // @author 路人丙 @煎蛋 // @icon  // @match https://jandan.net/treehole // @match https://jandan.net/treehole/* // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; // 要屏蔽的用户名列表(可添加登录或匿名用户名) const blockedUsers = ['俱舍莲帝', '用户1', '用户2']; // 在此添加更多用户名 // 主函数:屏蔽用户帖子的整个容器 function blockUserPosts() { const usernameElements = document.querySelectorAll('.author-logged, .author-anonymous'); usernameElements.forEach(usernameElement => { const username = usernameElement.textContent.trim(); if (blockedUsers.some(blocked => username.toLowerCase() === blocked.toLowerCase())) { // 尝试找到包含所有目标元素的父级容器 let postContainer = usernameElement.closest('.row, .comment-item, .list-item, .post, div[class*="comment"], li, article, section, div'); if (postContainer && postContainer.querySelector('.comment-meta') && postContainer.querySelector('.comment-content') && postContainer.querySelector('.comment-func')) { postContainer.style.display = 'none'; return; } // 备用逻辑:分别隐藏 comment-meta、comment-content 和 comment-func const metaElement = usernameElement.closest('.comment-meta'); if (metaElement && metaElement.parentElement) { const contentElement = metaElement.parentElement.querySelector('.comment-content'); const funcElement = metaElement.parentElement.querySelector('.comment-func'); if (metaElement) metaElement.style.display = 'none'; if (contentElement) contentElement.style.display = 'none'; if (funcElement) funcElement.style.display = 'none'; } } }); } // 初次加载时执行 blockUserPosts(); // 监控页面动态加载 const observer = new MutationObserver(() => blockUserPosts()); observer.observe(document.body, { childList: true, subtree: true }); })();