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('存储数据已清理!')
  }
})();