我的正则表达式有问题。我想翻译 BBCode 链接标签,例如:
[link=www.stackoverflow.com]Stack-Overflow[/link]
进入 HTML 链接:
<a href='www.stackoverflow.com'>Stack-Overflow</a>
。
在我的字符串中,可以在 BBCode 中创建多个链接。 我还需要一个将 HTML 翻译回 BBCode 的函数。
我的职能是:
BB代码转HTML:
$Text = preg_replace(
'/\[link=([^ ]+).*\](.*)\[\/link\]/',
'<a href="$1">$2</a>',
$Text
);
HTML 到 BBCode:
$Text = preg_replace(
'/\<a href="([^ ]+).*\">(.*)\<\/a\>/Usi',
'[link=$1]$2[/link]',
$Text
);
我对这些功能的问题是,当我有多个链接要转换时,它不起作用。
当我将一个链接翻译为 HTML 并且我想翻译回来时,我只有该链接的第一个字符。
至于你的第一个问题,
*
是贪婪的,所以它捕获第一个和最后一个链接之间的所有内容。一个简单的解决方案是使用非贪婪限定符,或者不允许 []
在您的组中:
\[link=([^ \[\]]+)\]([^\[\]]*)\[\/link\]
同样,反之亦然:
<a href="([^ "]+)">([^<]*?)\<\/a\>
这是非贪婪版本。它允许在链接中使用
[]
,甚至更短:
\[link=([^ ]*?)\](.*?)\[\/link\]
你的问题在于贪婪。* 使用 ?使其不贪婪。
$Text = preg_replace(
'/\[link=([^ ]+).*?\](.*?)\[\/link\]/',
'<a href="$1">$2</a>',
$Text
);