golonka/bbcodeparser

使用此库轻松解析BBCode。

v3.0 2019-07-30 20:09 UTC

This package is auto-updated.

Last update: 2024-09-29 04:19:44 UTC


README

Latest Version Software License Build Status 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>

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

$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 配置文件。

在此处,您只需将以下内容添加到您的 providers 数组中

'Golonka\BBCode\BBCodeParserServiceProvider'

并将其添加到您的 facades 数组中

'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)。有关更多信息,请参阅 许可文件