0

我有:

 <span>something or other</span>
 <b>blarg</b>
 <b>blarg and stuff</b>
 <span>blarg</span>
 <em>wakka wakka</em>
 <em>wakka blarg</em>
 <em>blarg</em>

我只想获取仅包含“blarg”且不包含其他文本的元素,因此:

 <b>blarg</b>
 <span>blarg</span>
 <em>blarg</em> 

这里的重要问题是我正在尝试检查 blarg 是否仅存在于页面上的一个元素中。我对正则表达式有一些普遍的运气,但我宁愿这样做,simple_html_dom这样我也可以查看子元素和兄弟元素。

有谁知道最简单的方法是什么simple_html_dom

4

1 回答 1

0

一种方法是解析每个标签,并测试它是否包含“blarg”......

这是一个工作示例:

$text = '<span>something or other</span>
 <b>blarg</b>
 <b>blarg and stuff</b>
 <span>blarg</span>
 <em>wakka wakka</em>
 <em>wakka blarg</em>
 <em>blarg</em>';

echo  "<div>Original Text: <xmp>$text</xmp></div>";

$html = str_get_html($text);

// Find all elements
$tags = $html->find('*');

foreach ($tags as $key => $tag) {
    // If text in tag contains 'blarg'
    if (strcmp(trim($tag->plaintext),'blarg') == 0) {
        echo  "<div> 'blarg' found in \$tags[$key]: <xmp>".$tag->outertext."</xmp></div>";
    }
}

我不知道你想做什么,但这可能是一个开始:)

于 2013-08-23T19:11:11.280 回答