(PHP 5 >= 5.0.1)
tidyNode::isHtml — このノードが HTML ドキュメントであるかどうかを調べる
このノードが HTML ドキュメントの一部であるかどうかを調べます。
ノードが HTML ドキュメントの一部である場合に TRUE、それ以外の場合に FALSE を返します。
例1 HTML ドキュメントからの HTML コードの抽出
<?php
$html = <<< HTML
<html><head>
<?php echo '<title>title</title>'; ?>
<#
/* JSTE code */
alert('Hello World');
#>
</head>
<body>
<?php
// PHP code
echo 'hello world!';
?>
<%
/* ASP code */
response.write("Hello World!")
%>
<!-- Comments -->
Hello World
</body></html>
Outside HTML
HTML;
$tidy = tidy_parse_string($html);
$num = 0;
get_nodes($tidy->html(), 'text');
function get_nodes($node, $node_type) {
// check if the current node is of requested type
if($node->{"is$node_type"}()) {
echo "\n\n# $node_type node #" . ++$GLOBALS['num'] . "\n";
echo $node->value;
}
// check if the current node has childrens
if($node->hasChildren()) {
foreach($node->child as $child) {
get_nodes($child, $node_type);
}
}
}
?>
上の例の出力は以下となります。
# html node #1
<html>
<head>
<?php echo '<title>title</title>'; ?><#
/* JSTE code */
alert('Hello World');
#>
<title></title>
</head>
<body>
<?php
// PHP code
echo 'hello world!';
?><%
/* ASP code */
response.write("Hello World!")
%><!-- Comments -->
Hello WorldOutside HTML
</body>
</html>
# html node #2
<head>
<?php echo '<title>title</title>'; ?><#
/* JSTE code */
alert('Hello World');
#>
<title></title>
</head>
# html node #3
<?php echo '<title>title</title>'; ?>
# html node #4
<#
/* JSTE code */
alert('Hello World');
#>
# html node #5
<title></title>
# html node #6
<body>
<?php
// PHP code
echo 'hello world!';
?><%
/* ASP code */
response.write("Hello World!")
%><!-- Comments -->
Hello WorldOutside HTML
</body>
# html node #7
<?php
// PHP code
echo 'hello world!';
?>
# html node #8
<%
/* ASP code */
response.write("Hello World!")
%>
# html node #9
<!-- Comments -->
# html node #10
Hello World
# html node #11
Outside HTML
注意: この関数は、PHP 4/Tidy 1 では tidy_node::is_html() という名前でした。