您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Convert URLs in text nodes to hyperlinks using regular expressions
当前为
// ==UserScript== // @name Convert Text to Hyperlink // @name:zh-CN 文本识别为超链接 // @namespace https://github.com/KPI0/tampermonkey // @version 1.3 // @description Convert URLs in text nodes to hyperlinks using regular expressions // @description:zh-cn 通过正则表达式将文本中的链接转换为超链接 // @author KPI0 // @match *://*/* // @exclude *://*.google.com/* // @exclude *://google.com/* // @exclude *://*.google.com.hk/* // @exclude *://google.com.hk/* // @icon  // @grant none // @license MIT // ==/UserScript== (function () { 'use strict'; // 正则表达式用于匹配以 http 或 https 开头的 URL const urlRegex = /(http:\/\/[^\s]+|https:\/\/[^\s]+)/g; function convertTextLinksToHyperlinks(node) { if (node.nodeType === Node.TEXT_NODE) { const text = node.nodeValue; const matches = text.match(urlRegex); if (matches) { const span = document.createElement('span'); let lastIndex = 0; matches.forEach((match) => { const matchIndex = text.indexOf(match, lastIndex); // 添加普通文本 if (matchIndex > lastIndex) { span.appendChild(document.createTextNode(text.substring(lastIndex, matchIndex))); } // 创建超链接元素 const link = document.createElement('a'); link.href = match; link.target = '_blank'; // 新标签打开 link.textContent = match; span.appendChild(link); lastIndex = matchIndex + match.length; }); // 添加剩余的普通文本 if (lastIndex < text.length) { span.appendChild(document.createTextNode(text.substring(lastIndex))); } node.parentNode.replaceChild(span, node); } } else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== 'A') { // 递归处理子节点,但不处理已经是链接的节点 for (let child of Array.from(node.childNodes)) { convertTextLinksToHyperlinks(child); } } } // 等待页面加载完成后执行 window.addEventListener('load', function () { convertTextLinksToHyperlinks(document.body); }); })();