アカデミックな演習としてWYSIWYGをゼロから構築しているところ、問題が発生しました。太字/斜体のアスタリスク、見出しのハスクマークなど、いくつかの基本的なMarkdownメソッドを使用して動作するように、WYSIWYGを構築しようとしています。しかし、ブロッククォートに問題が発生しました。ブロッククォートの入力を処理するために現在使用しているコードは次のとおりです。
$content = '$_POST['content'];
while (preg_match('^>\s(.*)$', $content)) {
$content = preg_replace('^>\s(.*)$', '<blockquote>$1</blockquote>', $content);
};
基本的に、「大なり記号」で始まる行を検索し、テキストを抽出して、次のようにブロック引用符タグに配置します。
input:
> this is a blockquote.
output:
<blockquote>this is a blockquote.</blockquote>
それは素晴らしいことですが、Markdownは複数行のブロッククォートを取得して単一のブロッククォートに変換することもできます。例えば:
input:
> this is a blockquote that
> i decided to separate across
> several lines.
output:
<blockquote>this is a blockquote that i decided to separate across several lines.</blockquote>
その機能を模倣したいのですが、現在のコードでは次のようになります。
output:
<blockquote>this is a blockquote that</blockquote><blockquote>i decided to separate across</blockquote><blockquote>several lines.</blockquote>
ブロッククォートを適切に連結する方法がわかりません。私が考えたアプローチの1つは、各行を変更してから、</blockquote><blockquote>
それらの間に二重改行を入れずに新しい検索を実行することでしたが、それは非効率的です。コードは次のようになります。
$content = '$_POST['content'];
while (preg_match('^>\s(.*)$', $content)) {
$matched = true;
$content = preg_replace('^>\s(.*)$', '<blockquote>$1</blockquote>', $content);
};
if ($matched) {
$content = preg_replace('</blockquote>(\n|\r)?<blockquote>', '', $content);
};
それでうまくいくと思いますが、正規表現を利用して先読みし、余分な行をすべて取得するより良い方法があるように感じます。残念ながら、それがどうなるかについてはわかりません。