令狐的轻量插件合集-超链接悬浮增加红色下划线、右键清除浏览器缓存、右键清除浏览器缓存、右键移除页面元素
// ==UserScript==
// @name LingHu's Collection Of Lightweight Plugins
// @version 0.1.3
// @author LingHu
// @homepage https://github.com/linghu-zhe/my-plug.git
// @namespace https://github.com/linghu-zhe/my-plug.git
// @description 令狐的轻量插件合集-超链接悬浮增加红色下划线、右键清除浏览器缓存、右键清除浏览器缓存、右键移除页面元素
// @icon 
// @grant unsafeWindow
// @grant GM_addStyle
// @grant GM_registerMenuCommand
// @connect *
// @match *://*/*
// @license MIT License
// ==/UserScript==
function log(msg, type = "log") {
console[type](msg)
}
// 清除所有Cookie
function clearAllCookie() {
var keys = document.cookie.match(/[^ =;]+(?=\=)/g);
if(keys) {
for(var i = keys.length; i--;) {
document.cookie = keys[i] + '=0;expires=' + new Date(0).toUTCString();
}
}
}
(function() {
'use strict';
try {
let external = `a.external:after { content:"";display:inline-flex;width:10px;height:10px;margin-left:4px;mask-image:url("");mask-size:cover;}`;
GM_addStyle(external);
// 超链接处理
var aList = document.getElementsByTagName("a");
if (aList && aList.length) {
for (let i = 0; i < aList.length; i++) {
let element = aList[i];
// -------超链接悬浮增加红色下划线---------
element.onmouseover = function () {
element.style.textDecoration = "underline red";
}
element.onmouseout = function () {
element.style.textDecoration = "unset";
}
// -------右键清除浏览器缓存---------
/* 必应搜索结果的进一步探索点击直接覆盖当前页面,每次都需要右击选择新标签,非常不爽。 */
/* element.onclick=(e) => {
e.preventDefault();
setTimeout(function() {
e.path.forEach(c => { if (c.nodeName === "A") { window.open(c.href); }})
}, 0);
}; */
}
}
// -------右键清除浏览器缓存---------
GM_registerMenuCommand("清除所有", function () {
localStorage.clear();
sessionStorage.clear();
clearAllCookie();
});
GM_registerMenuCommand("清除所有localStorage", function () {
localStorage.clear();
});
GM_registerMenuCommand("清除所有sessionStorage", function () {
sessionStorage.clear();
});
GM_registerMenuCommand("清除所有Cookie", function () {
clearAllCookie();
});
// -------生成信息---------
window.onload = () => {
// log("欢迎使用令狐的轻量插件合集,脚本启动成功, 当前版本:0.2.0");
}
// -------右键移除页面元素(刷新就会恢复|只是删除当前)---------
let event;
window.addEventListener('contextmenu', function(eventC) {
event = eventC;
});
GM_registerMenuCommand("右键移除页面元素(刷新恢复)", function () {
if(event) {
event.target.remove();
}
});
} catch (error) {
log(error);
}
})();