PHP Velho Oeste 2024

bbcode_create

(PECL bbcode >= 0.9.0)

bbcode_createBBCode リソースを作成する

説明

bbcode_create ([ array $bbcode_initial_tags = NULL ] ) : resource

この関数は、新しい BBCode リソースを返します。 これを用いて BBCode 文字列をパースします。

パラメータ

bbcode_initial_tags

タグ名をキー、BBCode を正しくパースするために必要なパラメータをその値とする連想配列。 以下の キー/値 のペアが使用可能です。

  • flags (任意) - BBCODE_FLAGS_* 定数を組み合わせたフラグ。
  • type (必須) - タグの種類を表す整数値。BBCODE_TYPE_* 定数を使用します。
  • open_tag (必須) - 開始タグ用の HTML 置換文字列。
  • close_tag (必須) - 終了タグ用の HTML 置換文字列。
  • default_arg (任意) - tag_type が OPTARG で、 引数が指定されていない場合に使用するデフォルトの引数。
  • content_handling (任意) - コンテンツの変更時に使用するコールバックの名前を指定します。 オブジェクト指向の記法は 0.10.1 以降でしかサポートしていません。 コールバック関数のプロトタイプは string name(string $content, string $argument) となります。
  • param_handling (任意) - 引数の変更時に使用するコールバックの名前を指定します。 オブジェクト指向の記法は 0.10.1 以降でしかサポートしていません。 コールバック関数のプロトタイプは string name(string $content, string $argument) となります。
  • childs (任意) - このタグの子として使用できるタグのリスト。 カンマ区切りの文字列で指定します。 先頭が ! の場合は、指定したタグ以外のすべての子を許可します。
  • parent (任意) - このタグの親として使用できるタグのリスト。 カンマ区切りの文字列で指定します。

返り値

BBCode_Container を返します。

例1 bbcode_create() の例

<?php
$arrayBBCode
=array(
    
''=>         array('type'=>BBCODE_TYPE_ROOT,  'childs'=>'!i'),
    
'i'=>        array('type'=>BBCODE_TYPE_NOARG'open_tag'=>'<i>',
                    
'close_tag'=>'</i>''childs'=>'b'),
    
'url'=>      array('type'=>BBCODE_TYPE_OPTARG,
                    
'open_tag'=>'<a href="{PARAM}">''close_tag'=>'</a>',
                    
'default_arg'=>'{CONTENT}',
                    
'childs'=>'b,i'),
    
'img'=>      array('type'=>BBCODE_TYPE_NOARG,
                    
'open_tag'=>'<img src="''close_tag'=>'" />',
                    
'childs'=>''),
    
'b'=>        array('type'=>BBCODE_TYPE_NOARG'open_tag'=>'<b>',
                    
'close_tag'=>'</b>'),
);
$text=<<<EOF
[b]太字のテキスト[/b]
[i]斜体のテキスト[/i]
[url]http://www.php.net/[/url]
[url=http://pecl.php.net/][b]PECL のサイト[/b][/url]
[img]http://static.php.net/www.php.net/images/php.gif[/img]
[url=http://www.php.net/]
[img]http://static.php.net/www.php.net/images/php.gif[/img]
[/url]
EOF;
$BBHandler=bbcode_create($arrayBBCode);
echo 
bbcode_parse($BBHandler,$text);
?>

上の例の出力は以下となります。

<b>太字のテキスト</b>
[i]斜体のテキスト[/i]
<a href="http://www.php.net/">http://www.php.net/</a>
<a href="http://pecl.php.net/"><b>PECL のサイト</b></a>
<img src="http://static.php.net/www.php.net/images/php.gif" />
<a href="http://www.php.net/">
[img]http://static.php.net/www.php.net/images/php.gif[/img]
</a>

add a note add a note

User Contributed Notes 1 note

up
27
rothenbergxxx at gmail dot com
14 years ago
For those without the BBCode extension, here's a relatively elegant function to do the trick.
Keep in mind that if you're using XHTML and one of your users tries to overlap lags <b>Like <i>so</b></i>, it will invalidate your markup. Still working on an expression for this.

<?php
   
function bb_parse($string) {
       
$tags = 'b|i|size|color|center|quote|url|img';
        while (
preg_match_all('`\[('.$tags.')=?(.*?)\](.+?)\[/\1\]`', $string, $matches)) foreach ($matches[0] as $key => $match) {
            list(
$tag, $param, $innertext) = array($matches[1][$key], $matches[2][$key], $matches[3][$key]);
            switch (
$tag) {
                case
'b': $replacement = "<strong>$innertext</strong>"; break;
                case
'i': $replacement = "<em>$innertext</em>"; break;
                case
'size': $replacement = "<span style=\"font-size: $param;\">$innertext</span>"; break;
                case
'color': $replacement = "<span style=\"color: $param;\">$innertext</span>"; break;
                case
'center': $replacement = "<div class=\"centered\">$innertext</div>"; break;
                case
'quote': $replacement = "<blockquote>$innertext</blockquote>" . $param? "<cite>$param</cite>" : ''; break;
                case
'url': $replacement = '<a href="' . ($param? $param : $innertext) . "\">$innertext</a>"; break;
                case
'img':
                    list(
$width, $height) = preg_split('`[Xx]`', $param);
                   
$replacement = "<img src=\"$innertext\" " . (is_numeric($width)? "width=\"$width\" " : '') . (is_numeric($height)? "height=\"$height\" " : '') . '/>';
                break;
                case
'video':
                   
$videourl = parse_url($innertext);
                   
parse_str($videourl['query'], $videoquery);
                    if (
strpos($videourl['host'], 'youtube.com') !== FALSE) $replacement = '<embed src="http://www.youtube.com/v/' . $videoquery['v'] . '" type="application/x-shockwave-flash" width="425" height="344"></embed>';
                    if (
strpos($videourl['host'], 'google.com') !== FALSE) $replacement = '<embed src="http://video.google.com/googleplayer.swf?docid=' . $videoquery['docid'] . '" width="400" height="326" type="application/x-shockwave-flash"></embed>';
                break;
            }
           
$string = str_replace($match, $replacement, $string);
        }
        return
$string;
    }
?>

[EDIT BY danbrown AT php DOT net: Contains a bugfix provided by (ramonvandam AT gmail DOT com) on 04-SEP-09 to address an improperly-defined parameter.  Also contains a bugfix provided by (pompei2 AT gmail DOT com) on 15-FEB-10 to address improperly-closed tags.  Plus, contains another bugfix provided by (angad AT wootify DOT com) on 18-JUL-2011 to fix an issue where unsupported tags provided to the function could cause the script to time out.]
To Top