将 BBCode [link='www.example.com]example[/link] 转换为 HTML <a href="www.example.com">example</a>

问题描述 投票:0回答:2

我的正则表达式有问题。我想翻译 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 并且我想翻译回来时,我只有该链接的第一个字符。

php regex replace text-parsing bbcode
2个回答
5
投票

至于你的第一个问题,

*
是贪婪的,所以它捕获第一个和最后一个链接之间的所有内容。一个简单的解决方案是使用非贪婪限定符,或者不允许
[]
在您的组中:

\[link=([^ \[\]]+)\]([^\[\]]*)\[\/link\]

同样,反之亦然:

<a href="([^ "]+)">([^<]*?)\<\/a\>

这是非贪婪版本。它允许在链接中使用

[]
,甚至更短:

\[link=([^ ]*?)\](.*?)\[\/link\]

0
投票

你的问题在于贪婪。* 使用 ?使其不贪婪。

$Text = preg_replace(
    '/\[link=([^ ]+).*?\](.*?)\[\/link\]/',
    '<a href="$1">$2</a>',
    $Text
);
最新问题
© www.soinside.com 2019 - 2024. All rights reserved.