Remove Perplexity Banners (Efficient)

Remove Comet promotion and thread warning banners

目前為 2025-11-14 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name        Remove Perplexity Banners (Efficient)
// @match       https://www.perplexity.ai/*
// @grant       none
// @version     1.2
// @license     MIT
// @description Remove Comet promotion and thread warning banners
// @namespace your.namespace
// ==/UserScript==

(function() {
    'use strict';
    
    function removeBanners() {
        // Target the common banner container classes
        const selectors = [
            'div.rounded-xl.shadow-xl',
            'div[role="alert"]',
            'div.h-bannerHeight'
        ];
        
        selectors.forEach(selector => {
            const elements = document.querySelectorAll(selector);
            elements.forEach(el => {
                const text = el.textContent;
                if (text.includes('Comet can do this faster') || 
                    text.includes('Thread is getting long') ||
                    text.includes('Save this thread as a Space') ||
                    text.includes('Get AI power in your browser with Comet')) {
                    el.remove();
                }
            });
        });
    }
    
    // Run immediately on page load
    removeBanners();
    
    // Watch for new elements being added
    const observer = new MutationObserver((mutations) => {
        removeBanners();
    });
    
    // Start observing the document body for changes
    observer.observe(document.body, {
        childList: true,
        subtree: true
    });
})();