您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Delete all Messages in AliExpress.
// ==UserScript== // @name AliExpress Bulk Delete All Messages (Auto-Confirm) // @namespace https://github.com/Springers // @version 1.001 // @author Springer // @description Delete all Messages in AliExpress. // @homepageURL https://github.com/Springers/UserScripts/blob/main/AliExpress_Bulk_Delete_All_Messages_(Auto-Confirm).user.js // @homepageURL https://github.com/Springers // @homepageURL https://greasyfork.org/en/scripts/548123 // @homepageURL https://greasyfork.org/en/users/1448667 // @icon  // @license Non-Commercial Use Only // @match *://*.aliexpress.com/p/message/index.html* // @include *://*.aliexpress.com/p/message/* // @grant none // @run-at document-idle // ==/UserScript== (function() { 'use strict'; // ── CONFIG ─────────────────────────────────────────────────────────── const POLL_INTERVAL = 200; // ms between checks for icon count const DELETE_TIMEOUT = 5000; // max ms to wait for a message to vanish const DELETE_DELAY = 300; // ms after clicking “×” before polling // ───────────────────────────────────────────────────────────────────── // 1) Override native confirm() so browser dialogs auto-return true window.confirm = () => true; // 2) Helper to dispatch real mouse events on SVG or any element function dispatchClick(el) { ['mousedown','mouseup','click'].forEach(type => el.dispatchEvent(new MouseEvent(type, { view: window, bubbles: true, cancelable: true })) ); } // 3) Grab all the SVG “×” delete icons function getDeleteIcons() { return Array.from( document.querySelectorAll('svg[role="button"][viewBox="0 0 12 12"]') ); } // 4) Wait until the number of delete icons decreases (i.e., a message was removed) async function waitForRemoval(previousCount) { const start = Date.now(); while (Date.now() - start < DELETE_TIMEOUT) { if (getDeleteIcons().length < previousCount) return; await new Promise(res => setTimeout(res, POLL_INTERVAL)); } throw new Error('Timed out waiting for conversation removal'); } // 5) Core loop: click each icon, wait for removal async function deleteAllMessages() { let icons; while ((icons = getDeleteIcons()).length) { const beforeCount = icons.length; const icon = icons[0]; icon.scrollIntoView({ block: 'center' }); dispatchClick(icon); // give the UI a moment to process await new Promise(res => setTimeout(res, DELETE_DELAY)); // wait until that message disappears await waitForRemoval(beforeCount); } alert('✅ All messages deleted!'); } // 6) Inject “Delete All” button once icons exist function injectButton() { if (document.getElementById('tm-delete-all-btn')) return; if (!getDeleteIcons().length) return; const btn = document.createElement('button'); btn.id = 'tm-delete-all-btn'; btn.textContent = 'Delete All'; Object.assign(btn.style, { position: 'fixed', top: '16px', right:'16px', zIndex: 9999, padding: '8px 14px', background: '#d32f2f', color: '#fff', border: 'none', borderRadius: '4px', fontSize: '14px', cursor: 'pointer', boxShadow: '0 2px 6px rgba(0,0,0,0.3)' }); btn.addEventListener('click', () => { btn.disabled = true; deleteAllMessages().catch(err => { alert('⚠️ ' + err.message); console.error(err); }); }); document.body.appendChild(btn); } // 7) Poll until the UI is ready, then inject the button window.addEventListener('load', () => { injectButton(); const intervalId = setInterval(() => { injectButton(); if (document.getElementById('tm-delete-all-btn')) { clearInterval(intervalId); } }, 1000); }); })();