저는 자동으로 HTML 주석을 처리하는 Joomla 용 플러그인을 작성했습니다. {dropcap} B {/ dropcap}을 입력하고 드롭 뚜껑 스타일을 만듭니다.PHP 정규 표현식의 파이프 관련 문제
매개 변수를 플러그인에 전달하는 방법이 필요 했으므로 {dropcap} B | FF00FF | 00FF00 {/ dropcap}이 가장 좋습니다. 내가 사용하는 경우
if (preg_match_all('/{dropcap}(.+?){\/dropcap}/', $row->text, $matches, PREG_PATTERN_ORDER) > 0)
{
foreach ($matches[0] as $match)
{
$SimpleDropCapPlugin->html = "";
$_temp = preg_replace("/{.+?}/", "", $match);
$_params = explode('|', $_temp);
$SimpleDropCapPlugin->text_dropcap = $_params[0];
if ($_params[1])
$SimpleDropCapPlugin->colour_border = '#' . $_params[1];
if ($_params[2])
$SimpleDropCapPlugin->colour_background = '#' . $_params[2];
if ($_params[3])
$SimpleDropCapPlugin->colour_text = '#' . $_params[3];
if ($_params[4])
$SimpleDropCapPlugin->font_size = $_params[4];
if ($_params[5])
$SimpleDropCapPlugin->font_family = $_params[5];
$SimpleDropCapPlugin->html .= "<span style=\"border: 1px solid " . $SimpleDropCapPlugin->colour_border . "; background: " . $SimpleDropCapPlugin->colour_background . " none repeat scroll 0% 0%; margin-right: 6px; margin-top: 5px; float: left; color: " . $SimpleDropCapPlugin->colour_text . "; -moz-background-clip: -moz-initial; -moz-background-origin: -moz-initial; -moz-background-inline-policy: -moz-initial; font-size: " . $SimpleDropCapPlugin->font_size . "px; line-height: 60px; padding-top: 2px; padding-right: 5px; font-family: " . $SimpleDropCapPlugin->font_family . ";\">";
$SimpleDropCapPlugin->html .= strtoupper($SimpleDropCapPlugin->text_dropcap);
$SimpleDropCapPlugin->html .= "</span>";
$row->text = preg_replace("#{dropcap}".$_temp."{/dropcap}#s", $SimpleDropCapPlugin->html , $row->text);
}
}
'|'
나는 함수를 생성 문자가 스크립트는 작동하지만 파이프 문자가 사용될 때마다 별도의 dropcap이 생성됩니다. 반면에 다른 분리자를 사용하는 경우 ':'스크립트가 정상적으로 작동합니다.파이프 문자를 HTML에서 일반적으로 사용하지 않으므로이 플러그 문자 사용을 확장 할 수 있으므로이 이상한 동작을 막을 수있는 방법이 있습니까?