文本识别为超链接

通过正则表达式将文本中的链接转换为超链接

  1. // ==UserScript==
  2. // @name Convert Text to Hyperlink
  3. // @name:zh-CN 文本识别为超链接
  4. // @namespace https://github.com/KPI0/tampermonkey
  5. // @version 1.5
  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. // Regular expression to match URLs starting with http or https
  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. // Append normal text
  34. if (matchIndex > lastIndex) {
  35. span.appendChild(document.createTextNode(text.substring(lastIndex, matchIndex)));
  36. }
  37.  
  38. // Create hyperlink element
  39. const link = document.createElement('a');
  40. link.href = match;
  41. link.target = '_blank'; // Open in a new tab
  42. link.textContent = match;
  43. span.appendChild(link);
  44.  
  45. lastIndex = matchIndex + match.length;
  46. });
  47.  
  48. // Append remaining normal text
  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) {
  56. // Skip certain tags that should not contain links or be processed
  57. const skipTags = ['A', 'SCRIPT', 'STYLE', 'IMG', 'VIDEO', 'AUDIO', 'PICTURE', 'IFRAME', 'BUTTON', 'CANVAS', 'NAV', 'HEADER', 'FOOTER'];
  58. if (!skipTags.includes(node.tagName)) {
  59. // Recursively process child nodes
  60. for (let child of Array.from(node.childNodes)) {
  61. convertTextLinksToHyperlinks(child);
  62. }
  63. }
  64. }
  65. }
  66.  
  67. // Execute after the page has fully loaded
  68. window.addEventListener('load', function () {
  69. const mainContentSelectors = ['#main', '.content', '.article', '#content', '.post', '.entry']; // Common main content containers
  70. mainContentSelectors.forEach(selector => {
  71. const container = document.querySelector(selector);
  72. if (container) {
  73. convertTextLinksToHyperlinks(container);
  74. }
  75. });
  76. });
  77.  
  78. })();