Greasy Fork is available in English.
将鼠标放置在不想要的网页内容上然后点击即可去掉,适用于想要将网页保存为pdf时但有不需要内容时的场景
// ==UserScript==
// @name 哪里不要点哪里
// @namespace http://tampermonkey.net/
// @version 1.0.2
// @description 将鼠标放置在不想要的网页内容上然后点击即可去掉,适用于想要将网页保存为pdf时但有不需要内容时的场景
// @author starrysky
// @match https://*/*
// @match http://*/*
// @grant none
// ==/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('存储数据已清理!')
}
})();