1

次のようなHTML文字列を指定します。

Lorem ipsum dolor sit amet, <a href="#">consectetuer adipiscing</a>
elit, <strong>tincidunt</strong> ut volutpat.

<span>すべての単語を要素で囲むにはどうすればよいですか。次のようになります。

<span>Lorem</span> <span>ipsum</span> <span>dolor</span> <span>sit</span>
<span>amet,</span> <a href="#"><span>consectetuer</span> <span>adipiscing</span></a>
<span>elit,</span> <strong><span>tincidunt</span></strong> <span>ut</span>
<span>volutpat.</span>
4

3 に答える 3

3

より単純なアプローチ

preg_replace('([a-zA-Z.,!?0-9]+(?![^<]*>))', '<span>$0</span>', '{{your data}}');

の単語を除く<span>、語彙のすべての単語で囲まれています。 必要に応じて語彙を簡単に変更できるようになりました。たとえば、単一の句読点を囲まれたくない場合などです。[a-zA-Z.,!?0-9]+<brackets>

于 2012-08-10T14:23:30.180 に答える
1

私はこれを試しました、これがあなたが探しているものだと思います:

$result = preg_replace("/(<[^>]+>)?\\w*/us", "<span>$0</span>", $searchText);

これが入力です

Lorem ipsum dolor sit amet, <a href="#">consectetuer adipiscing</a>elit, <strong>tincidunt</strong> ut volutpat.

そして、これが出力です

<span>Lorem</span> <span>ipsum</span> <span>dolor</span> <span>sit</span> <span>amet</span>, <span><a href="#">consectetuer</span> <span>adipiscing</span><span></a></span><span>elit</span>, <span><strong>tincidunt</span><span></strong></span> <span>ut</span> <span>volutpat</span>.
于 2012-08-10T14:39:24.477 に答える
1

@daftcoder のソリューションが機能する場合、それは素晴らしいことですが、コードにエンティティ (< など) がある場合は失敗します。他に失敗した例は見つかりませんでした。

それが重要な場合は、PHP で DOM 操作を使用できます。これはかなり複雑ですが、単純な正規表現よりも多くの場合に機能するはずです。

walk 関数と doReplace 関数は、別の質問への回答から JS から PHP に変換されます。( HTML テキスト内の個々の単語を SPAN タグで囲みますか? )

<?php

echo wrap_words('span', 'Lorem ipsum dolor sit amet, <a href="#">consectetuer adipiscing</a> elit, <strong>tincidunt</strong> ut volutpat.');

function wrap_words($tag, $text) {
    $document = new DOMDocument();
    $fragment = $document->createDocumentFragment();
    $fragment->appendXml($text);
    walk($tag, $fragment);
    $html = $document->saveHtml($fragment);
    // using saveHTML with a documentFragment can leave an invalid "<>"
    // at the beginning of the string - remove it
    return preg_replace('/^<>/', '', $html);
}

function walk($tag, $root)
{
    if ($root->nodeType == XML_TEXT_NODE)
    {
        doReplace($tag, $root);
        return;
    }
    $children = $root->childNodes;
    for ($i = $children->length - 1; $i >= 0; $i--)
    {
        walk($tag, $children->item($i));
    }
}

function doReplace($tag, $text)
{
    $fragment = $text->ownerDocument->createDocumentFragment();
    $fragment->appendXML(preg_replace('/\S+/', "<{$tag}>\$0</{$tag}>", $text->nodeValue));
    $parent = $text->parentNode;
    $children = $fragment->childNodes;
    for ($i = $children->length - 1; $i >= 0; $i--)
    {
        $parent->insertBefore($children->item($i), $text->nextSibling);
    }
    $parent->removeChild($text);
}
于 2012-08-10T16:00:02.730 に答える