简易拖拽
// ==UserScript==
// @name 简易拖拽
// @namespace f+drag
// @version 2024.03.26
// @icon 
// @description 拖动文字、图片、链接时新窗口打开(拖拽距离超过15px,时间在1.2秒内)
// @author f+
// @match *://*/*
// @grant none
// ==/UserScript==
(function () {
"use strict";
const requiredDistance = 15;
let startY;
let startX;
const upperTimeLimit = 1200;
let startTime;
let link;
let image;
let text;
// 重置状态
function reset() {
startY = void 0;
startX = void 0;
startTime = void 0;
link = void 0;
image = void 0;
text = void 0;
}
// 记录拖拽起始
function setStart(event) {
startY = event.clientY;
startX = event.clientX;
startTime = new Date();
}
// 判断是否是图片链接
function isImageLink(link) {
if (!link || !link.href) {
return false;
}
const imageExtensions = [".jpg", ".jpeg", ".png", ".gif", ".bmp", ".webp"];
const lowerHref = link.href.toLowerCase();
return imageExtensions.some((ext) => lowerHref.endsWith(ext));
}
// 监听拖放开始事件
document.addEventListener("dragstart", function (event) {
// 获取拖动的链接元素
if ("closest" in event.target) {
link = event.target.closest("a");
image = event.target.closest("img");
if (link || image) {
// 记录初始位置
setStart(event);
}
} else {
const selection = window.getSelection();
if (selection) {
// 判断选中的文本anchorNode跟拖动srcElement的关系
if (selection.anchorNode === event.target) {
text = selection.toString().trim();
setStart(event);
}
}
}
});
// 监听拖放结束事件
document.addEventListener("dragend", function (event) {
function isGoodDrag() {
const distanceY = Math.abs(event.clientY - startY);
const distanceX = Math.abs(event.clientX - startX);
const isDragged = distanceY > requiredDistance && distanceX * 4 < distanceY;
const isIntime = new Date() - startTime < upperTimeLimit;
return isDragged && isIntime;
}
if (isGoodDrag()) {
if (link || image || text) {
// 获取链接的 URL
let url;
if (text) {
// 文本拥有最高优先级
if (text.startsWith("http://") || text.startsWith("https://")) {
url = text;
} else {
url = `https://cn.bing.com/search?q=${encodeURIComponent(text)}&FORM=PORE`;
}
} else if (isImageLink(link)) {
// 其次是如果link是图片则为该link
url = link.href;
} else if (image && image.src) {
// 再次是image
url = image.src;
} else if (link && link.href) {
// 最后是其他link
url = link.href;
}
if (url) {
console.log("超级拖拽");
// 阻止默认的拖放行为
if (event.cancelable) event.preventDefault();
event.stopImmediatePropagation();
// 在后台打开链接
window.open(url, "_blank");
}
}
}
// 重置状态
reset();
});
})();