自动检测文本区域字段中的链接

发布于 2025-01-09 23:24:36 字数 447 浏览 0 评论 0原文

如何突出显示文本区域中的超链接。 我创建了一个如下所示的标签,

     <textarea
        class="textarea"
        name="input_note"
        id=""
        cols="30"
        rows="10"
      ></textarea>

假设这个输入字段用于记笔记并保存在那里(更像是谷歌保留)。因此,当用户在输入字段中输入任何“链接”时,链接将显示为纯文本而不是超链接。该链接也不像通常那样突出显示。

---输入字段我已保存了带有链接的注释 - 'https://stackoverflow.com/' 但是当显示注释时,

> https://stackoverflow.com/

会显示纯文本并且不可单击。

How can I highlight hyperlinks in textarea.
I have created a tag as shown below

     <textarea
        class="textarea"
        name="input_note"
        id=""
        cols="30"
        rows="10"
      ></textarea>

let's say this input field is used to take a note and saves there(more like a google keep). so when the user inputs any 'links' in the input field, the links are shown as plain text instead of hyperlink. The link is also not highlight as normally has.

---input field I have saved a note with the link- 'https://stackoverflow.com/'
but when the note is displayed

> https://stackoverflow.com/

plain text is displayed and not clickable.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

罪歌 2025-01-16 23:24:36

这段代码应该可以工作。我必须用 div 替换 textarea,因为它不可能在 textarea 中执行您想要的操作,但我给了它样式,使其看起来就像 textarea 一样。

function linkify(inputText) {
  var replacedText, replacePattern1, replacePattern2, replacePattern3;
  if (inputText.indexOf("<a ")) {
    //URLs starting with http://, https://, or ftp://
    replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;
    replacedText = inputText.replace(replacePattern1, '<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="$1" target="_blank">$1</a></div>');

    //URLs starting with "www." (without // before it, or it'd re-link the ones done above).
    replacePattern2 = /(^|[^\/])(www\.[\S]+(\b|$))/gim;
    replacedText = replacedText.replace(replacePattern2, '$1<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="http://$2" target="_blank">$2</a></div>');

    //Change email addresses to mailto:: links.
    replacePattern3 = /(([a-zA-Z0-9\-\_\.])+@[a-zA-Z\_]+?(\.[a-zA-Z]{2,6})+)/gim;
    replacedText = replacedText.replace(replacePattern3, '<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="mailto:$1">$1</a></div>');
  } else {
    replacedText = inputText;
  }
  alert(replacedText)
  return replacedText;
}
.textarea {
  border: 1px solid gray;
  min-height: 50px;
  /* if you want Flexible textarea/div then give min-height instead of height */
  overflow: auto;
  padding: 2px;
  resize: both;
  width: 400px;
  font-size: 15px;
  color: #000;
}
<div class="textarea" name="input_note" id="textarea" cols="30" rows="10" contenteditable onblur="  var text = document.getElementById('textarea').innerHTML;var text = linkify(text);document.getElementById('textarea').innerHTML = text;"></div>

Stackoverflow has blocked <a tags so you wont be able to go to a website if u try to run the snippet. Copy the code in the file and it would work.

This code should work. I had to replace the textarea with div because its impossible to do what you want in textarea but I gave it styling so that it looks just like a textarea.

function linkify(inputText) {
  var replacedText, replacePattern1, replacePattern2, replacePattern3;
  if (inputText.indexOf("<a ")) {
    //URLs starting with http://, https://, or ftp://
    replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;
    replacedText = inputText.replace(replacePattern1, '<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="$1" target="_blank">$1</a></div>');

    //URLs starting with "www." (without // before it, or it'd re-link the ones done above).
    replacePattern2 = /(^|[^\/])(www\.[\S]+(\b|$))/gim;
    replacedText = replacedText.replace(replacePattern2, '$1<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="http://$2" target="_blank">$2</a></div>');

    //Change email addresses to mailto:: links.
    replacePattern3 = /(([a-zA-Z0-9\-\_\.])+@[a-zA-Z\_]+?(\.[a-zA-Z]{2,6})+)/gim;
    replacedText = replacedText.replace(replacePattern3, '<div contentEditable="false" style="display: inline-block; padding: 5px;"><a href="mailto:$1">$1</a></div>');
  } else {
    replacedText = inputText;
  }
  alert(replacedText)
  return replacedText;
}
.textarea {
  border: 1px solid gray;
  min-height: 50px;
  /* if you want Flexible textarea/div then give min-height instead of height */
  overflow: auto;
  padding: 2px;
  resize: both;
  width: 400px;
  font-size: 15px;
  color: #000;
}
<div class="textarea" name="input_note" id="textarea" cols="30" rows="10" contenteditable onblur="  var text = document.getElementById('textarea').innerHTML;var text = linkify(text);document.getElementById('textarea').innerHTML = text;"></div>

Stackoverflow has blocked <a tags so you wont be able to go to a website if u try to run the snippet. Copy the code in the file and it would work.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文