gpt4 book ai didi

javascript - 正则表达式在不破坏现有 HTML 代码的情况下转换链接中的主题标签

转载 作者:搜寻专家 更新时间:2023-11-01 05:02:01 25 4
gpt4 key购买 nike

我想将 javascript 字符串中的所有 URL 都转换为链接,在这个字符串中还有以 # 标签开头的单词。

截至目前,我在级联中创建了两个正则表达式,一个基于 url 创建 html anchor 标记,另一个为主题标签创建 anchor 标记(如在 Twitter 中)。

我在尝试将 www.sitename.com/index.php#someAnchor 解析为正确的标记时遇到了很多问题。

content = urlifyLinks(content);
content = urlifyHashtags(content);

其中两个函数如下:

function urlifyHashtags(text) {
var hashtagRegex = /^#([a-zA-Z0-9]+)/g;
var tempText = text.replace(hashtagRegex, '<a href="index.php?keywords=$1">#$1</a>');

var hashtagRegex2 = /([^&])#([a-zA-Z0-9]+)/g;
tempText = tempText.replace(hashtagRegex2, '$1<a href="index.php?keywords=$2">#$2</a>');

return tempText;
}

function urlifyLinks(inputText) {
var replaceText, replacePattern1, replacePattern2, replacePattern3;

replacePattern1 = /(\b(https?|ftp):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/gim;
replacedText = inputText.replace(replacePattern1, '<a href="$1" target="_blank">$1</a>');

replacePattern2 = /(^|[^\/])(www\.[\S]+(\b|$))/gim;
replacedText = replacedText.replace(replacePattern2, '$1<a href="http://$2" target="_blank">$2</a>');

replacePattern3 = /(\w+@[a-zA-Z_]+?\.[a-zA-Z]{2,6})/gim;
replacedText = replacedText.replace(replacePattern3, '<a href="mailto:$1">$1</a>');
return replacedText;
}

我正在考虑解析 urlifyLinks 的输出并将正则表达式应用于第一层的所有文本元素的 dom 元素,这是一件很丑陋的事情吗?

最佳答案

您可以通过使用带有回调函数替换的单个正则表达式来避免此问题。

For example:

function linkify(str){
// order matters
var re = [
"\\b((?:https?|ftp)://[^\\s\"'<>]+)\\b",
"\\b(www\\.[^\\s\"'<>]+)\\b",
"\\b(\\w[\\w.+-]*@[\\w.-]+\\.[a-z]{2,6})\\b",
"#([a-z0-9]+)"];
re = new RegExp(re.join('|'), "gi");

return str.replace(re, function(match, url, www, mail, twitler){
if(url)
return "<a href=\"" + url + "\">" + url + "</a>";
if(www)
return "<a href=\"http://" + www + "\">" + www + "</a>";
if(mail)
return "<a href=\"mailto:" + mail + "\">" + mail + "</a>";
if(twitler)
return "<a href=\"foo?bar=" + twitler + "\">#" + twitler + "</a>";

// shouldnt get here, but just in case
return match;
});
}

Twitler

关于javascript - 正则表达式在不破坏现有 HTML 代码的情况下转换链接中的主题标签,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10995516/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com