// ==UserScript== // @name 哪里不要点哪里 // @namespace http://tampermonkey.net/ // @version 1.0.2 // @description 将鼠标放置在不想要的网页内容上然后点击即可去掉,适用于想要将网页保存为pdf时但有不需要内容时的场景 // @author starrysky // @match https://*/* // @match http://*/* // @grant none // @downloadURL https://update.greasyfork.icu/scripts/416756/%E5%93%AA%E9%87%8C%E4%B8%8D%E8%A6%81%E7%82%B9%E5%93%AA%E9%87%8C.user.js // @updateURL https://update.greasyfork.icu/scripts/416756/%E5%93%AA%E9%87%8C%E4%B8%8D%E8%A6%81%E7%82%B9%E5%93%AA%E9%87%8C.meta.js // ==/UserScript== (function () { 'use strict' var CACAHE_KEY = 'start_sky_script_wipe' var OPERA_MODE = 1 // 1 普通模式 2 存储模式 3 清理缓存 var PAGE_ALL_DOMS // 全部dom var removeDomList = [] // 需要移除的dom window.addEventListener('load', registerClearScript) function registerClearScript() { PAGE_ALL_DOMS = document.querySelectorAll('*') removeFromCache() createOperaIcon() } function createOperaIcon() { // 容器 var iconWrap = document.createElement('div') iconWrap.style.position = 'fixed' iconWrap.style.left = window.innerWidth - 64 + 'px' iconWrap.style.top = window.innerHeight - 64 + 'px' iconWrap.style.display = 'flex' iconWrap.style.width = '40px' iconWrap.style.height = '40px' iconWrap.style.cursor = 'move' iconWrap.style.borderRadius = '50%' iconWrap.style.backgroundColor = 'rgba(24, 144, 255, 0.85)' iconWrap.style.zIndex = 9999 // 注册拖拽事件 var isDrag = false var offsetX = 0 var offsetY = 0 function handleTouchDown(event) { isDrag = true offsetX = event.clientX - iconWrap.getBoundingClientRect().left offsetY = event.clientY - iconWrap.getBoundingClientRect().top if (window.PointerEvent) { document.addEventListener('pointermove', handleTouchMove) } else { document.addEventListener('mousemove', handleTouchMove) } } function handleTouchMove(event) { if (!isDrag) { return } iconWrap.style.left = event.x - offsetX + 'px' iconWrap.style.top = event.y - offsetY + 'px' } function handleTouchUp() { isDrag = false if (window.PointerEvent) { document.removeEventListener('pointermove', handleTouchMove) } else { document.removeEventListener('mousemove', handleTouchMove) } } if (window.PointerEvent) { iconWrap.addEventListener('pointerdown', handleTouchDown) iconWrap.addEventListener('pointerup', handleTouchUp) } else { iconWrap.addEventListener('mousedown', handleTouchDown) iconWrap.addEventListener('mouseup', handleTouchUp) } // 图标 const iconEle = document.createElement('img') iconEle.style.width = '24px' iconEle.style.height = '24px' iconEle.style.margin = 'auto' iconEle.src = '' iconEle.addEventListener('dragstart', (event) => { event.preventDefault() return false }) iconWrap.appendChild(iconEle) // 选择模式 const btnWrap = document.createElement('div') btnWrap.style.display = 'none' btnWrap.style.position = 'absolute' btnWrap.style.left = '-100px' btnWrap.style.top = '-90px' const btnNoraml = document.createElement('button') btnNoraml.innerHTML = '普通模式' btnNoraml.dataset.code = 1 const btnStorage = document.createElement('button') btnStorage.innerHTML = '存储模式' btnStorage.dataset.code = 2 const btnClear = document.createElement('button') btnClear.innerHTML = '清除缓存' btnClear.dataset.code = 3 ;[btnNoraml, btnStorage, btnClear].forEach((ele) => { ele.style.display = 'inline-block' ele.style.width = '80px' ele.style.height = '30px' ele.style.margin = '5px 10px' ele.style.fontSize = '14px' ele.style.cursor = 'pointer' ele.onclick = function () { OPERA_MODE = parseInt(ele.dataset.code) startScript() btnWrap.style.display = 'none' } btnWrap.appendChild(ele) }) iconWrap.addEventListener('mouseenter', function () { btnWrap.style.display = 'block' }) iconWrap.addEventListener('mouseleave', function () { btnWrap.style.display = 'none' }) iconWrap.appendChild(btnWrap) // 注册关闭事件 iconWrap.addEventListener('dblclick', stopScript) document.body.appendChild(iconWrap) } // 开启 function startScript() { switch (OPERA_MODE) { case 1: case 2: addOperaEvent() break case 3: clearCache() break } } // 关闭 function stopScript() { PAGE_ALL_DOMS.forEach((ele) => { if (ele.nodeName !== 'HTML' && ele.nodeName !== 'SCRIPT' && ele.nodeName !== 'BODY') { if (ele.dataset.backgroundColor) { ele.style.backgroundColor = ele.dataset.backgroundColor } ele.removeEventListener('click', hanldeDomClick) ele.removeEventListener('mouseenter', handleDomMouseEnter) ele.removeEventListener('mouseout', handleDomMouseOut) } }) alert('【哪里不要点哪里】:脚本已关闭') } // 添加事件 function addOperaEvent() { PAGE_ALL_DOMS.forEach((ele) => { if (ele.nodeName !== 'HTML' && ele.nodeName !== 'SCRIPT' && ele.nodeName !== 'BODY') { ele.addEventListener('click', hanldeDomClick) ele.addEventListener('mouseenter', handleDomMouseEnter) ele.addEventListener('mouseout', handleDomMouseOut) } }) } // dom事件 function hanldeDomClick(event) { var target = event.target || event.srcElement if (OPERA_MODE === 2) { removeDomList.push(calcCssPath(target)) localStorage.setItem(CACAHE_KEY, JSON.stringify(removeDomList)) } target && target.remove() } function handleDomMouseEnter(event) { var ele = event.target || event.srcElement ele.dataset.backgroundColor = ele.style.backgroundColor ele.style.backgroundColor = 'rgba(78,110,242,0.15)' } function handleDomMouseOut(event) { var ele = event.target || event.srcElement console.log('1', 111, ele.dataset.backgroundColor) if (ele.dataset.backgroundColor) { ele.style.backgroundColor = ele.dataset.backgroundColor } } // 计算css路径 function calcCssPath(el) { if (!(el instanceof Element)) { return } var path = [] while (el.nodeType === Node.ELEMENT_NODE) { var selector = el.nodeName.toLowerCase() if (el.id) { selector += '#' + el.id path.unshift(selector) break } else { var sib = el, nth = 1 while ((sib = sib.previousElementSibling)) { if (sib.nodeName.toLowerCase() == selector) { nth++ } } if (nth != 1) { selector += ':nth-of-type(' + nth + ')' } } path.unshift(selector) el = el.parentNode } return path.join(' > ') } // 根据缓存移除内容 function removeFromCache() { var storageInfo = localStorage.getItem(CACAHE_KEY) if (storageInfo) { try { removeDomList = JSON.parse(storageInfo) removeDomList.forEach((selector) => { var node = document.querySelector(selector) node && node.remove() }) } catch (error) { console.error('【哪里不要点哪里】:异常错误', error) } } } // 清除缓存 function clearCache() { localStorage.removeItem(CACAHE_KEY) alert('存储数据已清理!') } })();