phainv/bbcodeparser

使用这个库轻松解析BBCode。

1.0.0 2017-12-06 09:25 UTC

This package is auto-updated.

Last update: 2024-09-08 19:09:31 UTC


README

Latest Version Software License Build Status Coverage Status Quality Score Total Downloads

使用Golonka\BBCodeParser包可以帮助您解析BBCode。

安装

通过Composer

$ composer require golonka/bbcodeparser

用法

解析文本就像这样简单!

$bbcode = new Golonka\BBCode\BBCodeParser;

echo $bbcode->parse('[b]Bold Text![/b]');
// <strong>Bold Text!</strong>

如果不想使用所有BBCode,只需这样做。

$bbcode = new Golonka\BBCode\BBCodeParser;

echo $bbcode->only('bold', 'italic')
            ->parse('[b][u]Bold[/u] [i]Italic[/i]![/b]');
            // <strong>[u]Bold[/u] <em>Italic</em>!</strong>

echo $bbcode->except('bold')
            ->parse('[b]Bold[/b] [i]Italic[/i]');
            // [b]Bold[/b] <em>Italic</em>

默认情况下,解析器是区分大小写的。但如果您希望解析器接受像[B]加粗文本[/B]这样的标签,那就非常简单。

$bbcode = new Golonka\BBCode\BBCodeParser;

// Case insensitive
echo $bbcode->parse('[b]Bold[/b] [I]Italic![/I]', true);
     // <strong>Bold</strong> <em>Italic!</em>

// Or like this

echo $bbcode->parseCaseInsensitive('[b]Bold[/b] [i]Italic[/i]');
     // <strong>Bold</strong> <em>Italic!</em>

您还可以使用另一个辅助函数更明确地表明解析器是区分大小写的。

    $bbcode = new Golonka\BBCode\BBCodeParser;

    echo $bbcode->parseCaseSensitive('[b]Bold[/b] [I]Italic![/I]');
         // <strong>Bold</strong> [I]Italic![/I]

如果您想完全删除所有BBCode,只需调用一个函数即可。

    $bbcode = new Golonka\BBCode\BBCodeParser;

    echo $bbcode->stripBBCodeTags('[b]Bold[/b] [i]Italic![/i]');
         // Bold Italic!

Laravel集成

Laravel集成非常简单,对于Laravel 4和Laravel 5都是相同的。只需打开您的app.php配置文件。

在这里,您只需将以下内容添加到您的提供者数组中

'Golonka\BBCode\BBCodeParserServiceProvider'

并将以下内容添加到您的外观数组中

'BBCode' => 'Golonka\BBCode\Facades\BBCodeParser'

语法与在纯PHP中使用时相同,但在方法前加上BBCode::。以下是一些示例。

// Simple parsing
echo BBCode::parse('[b]Bold Text![/b]');

// Limiting the parsers with the only method
echo BBCode::only('bold', 'italic')
        ->parse('[b][u]Bold[/u] [i]Italic[/i]![/b]');
        // <strong>[u]Bold[/u] <em>Italic</em>!</strong>

// Or the except method
echo BBCode::except('bold')
        ->parse('[b]Bold[/b] [i]Italic[/i]');
        // [b]Bold[/b] <em>Italic</em>

测试

$ phpunit

贡献

有关详细信息,请参阅CONTRIBUTING

鸣谢

许可证

MIT许可证(MIT)。有关更多信息,请参阅许可证文件