您需要先安装一个扩展,例如 篡改猴、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.0
- // @description Convert URLs in text nodes to hyperlinks using regular expressions
- // @description:zh-cn 通过正则表达式将文本中的链接转换为超链接
- // @author KPI0
- // @match *://*/*
- // @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);
- });
- })();