Convert Text to Hyperlink

Convert URLs in text nodes to hyperlinks using regular expressions

目前為 2024-10-05 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name Convert Text to Hyperlink
  3. // @name:zh-CN 文本识别为超链接
  4. // @namespace https://github.com/KPI0/tampermonkey
  5. // @version 1.0
  6. // @description Convert URLs in text nodes to hyperlinks using regular expressions
  7. // @description:zh-cn 通过正则表达式将文本中的链接转换为超链接
  8. // @author KPI0
  9. // @match *://*/*
  10. // @icon 
  11. // @grant none
  12. // @license MIT
  13. // ==/UserScript==
  14.  
  15. (function () {
  16. 'use strict';
  17.  
  18. // 正则表达式用于匹配以 http 或 https 开头的 URL
  19. const urlRegex = /(http:\/\/[^\s]+|https:\/\/[^\s]+)/g;
  20.  
  21. function convertTextLinksToHyperlinks(node) {
  22. if (node.nodeType === Node.TEXT_NODE) {
  23. const text = node.nodeValue;
  24. const matches = text.match(urlRegex);
  25.  
  26. if (matches) {
  27. const span = document.createElement('span');
  28. let lastIndex = 0;
  29.  
  30. matches.forEach((match) => {
  31. const matchIndex = text.indexOf(match, lastIndex);
  32.  
  33. // 添加普通文本
  34. if (matchIndex > lastIndex) {
  35. span.appendChild(document.createTextNode(text.substring(lastIndex, matchIndex)));
  36. }
  37.  
  38. // 创建超链接元素
  39. const link = document.createElement('a');
  40. link.href = match;
  41. link.target = '_blank'; // 新标签打开
  42. link.textContent = match;
  43. span.appendChild(link);
  44.  
  45. lastIndex = matchIndex + match.length;
  46. });
  47.  
  48. // 添加剩余的普通文本
  49. if (lastIndex < text.length) {
  50. span.appendChild(document.createTextNode(text.substring(lastIndex)));
  51. }
  52.  
  53. node.parentNode.replaceChild(span, node);
  54. }
  55. } else if (node.nodeType === Node.ELEMENT_NODE && node.tagName !== 'A') {
  56. // 递归处理子节点,但不处理已经是链接的节点
  57. for (let child of Array.from(node.childNodes)) {
  58. convertTextLinksToHyperlinks(child);
  59. }
  60. }
  61. }
  62.  
  63. // 等待页面加载完成后执行
  64. window.addEventListener('load', function () {
  65. convertTextLinksToHyperlinks(document.body);
  66. });
  67.  
  68. })();