Greasy Fork

来自缓存

Greasy Fork is available in English.

哪里不要点哪里

将鼠标放置在不想要的网页内容上然后点击即可去掉,适用于想要将网页保存为pdf时但有不需要内容时的场景

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

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