PHP使用DOMDocument类生成HTML实例(包含常见标签元

在这一章节里, 我们来了解下如何利用核心(core) PHP 生成 HTML 文件
 
最近我在查询 php.net 的时候,发现 DOMDocument 这个类非常的有意思, 可以用来生成 XML 或 HTML 文件, DOMDocument 为我们提供了一系列的方法来生成 XML/HTML 标签并插入到 DOM 中, 现在就让我们来看下如何生成的
 
这里先来看下, 利用它所提供的方法生成的效果, 见下图:

PHP使用DOMDocument类生成HTML实例(包含常见标签元

一、创建新的 DOM 文件

复制代码 代码如下:

//实例化 DOMDocument 类,并指定版本号
$dom = new DOMDocument('1.0');
 
//将生成的标签或代码输出到页面
echo $dom->saveHTML();


二、在 DOM 文件里添加新的 HTML 元素

复制代码 代码如下:

$css_text = 'p{color:#ff00ff;}';
 
//创建新的 style 标签和 CSS 内容
$style = $dom->createElement('style', $css_text);
 
//添加该 style 标签到 DOM 文件中
$dom->appendChild($style);
 
//如下是输出效果
<style>
    p{color:#ff00ff;}
</style>


这里需要说下就是 createElement 方法, 当你想创建 <style> 标签并写入 Css, 可以利用该方法的第二个参数作为 Css 内容,如上所示。 但如果你想创建 <br> 标签, 第二个参数即可省略, 如下:

复制代码 代码如下:


//创建新的 <br> 标签
$br = $dom->createElement('br');
 
//添加该 <br> 标签到 DOM 文件中
$dom->appendChild($br);


三、为 HTML 元素添加属性
 
HTML 元素拥有各种各样的属性, 为其添加属性可以用到 createAttribute() 方法

复制代码 代码如下:


$css_text = 'p{color:#ff00ff;}';
 
//创建新的 style 标签和 CSS 内容
$style = $dom->createElement('style', $css_text);
 
//创建新的属性 'type'
$domAttribute = $dom->createAttribute('type');
 
//为属性 'type' 添加值
$domAttribute->value = 'text/css';
 
//添加该属性到 style 标签中
$style->appendChild($domAttribute);
 
//添加该 style 标签到 DOM 文件中
$dom->appendChild($style);
 
//如下是输出效果
<style type="text/css">
    p{color:#ff00ff;}
</style>


复制代码 代码如下:


$p_text = 'This is a paragraph.';
 
//创建新的 p 标签和内容
$p = $dom->createElement('p', $p_text);
 
//创建新的属性 'id'
$domAttribute = $dom->createAttribute('id');
 
//为属性 'id' 添加值
$domAttribute->value = 'description';
 
//添加该属性到 p 标签中
$p->appendChild($domAttribute);
 
//添加该 p 标签到 DOM 文件中
$dom->appendChild($p);
 
//如下是输出效果
<p>
    某一天
</p>


四、添加 Form 元素
 
添加 textbox

复制代码 代码如下:


$input = $dom->createElement('input');
 
$domAttribute = $dom->createAttribute('type');
$domAttribute->value = 'text';
$input->appendChild($domAttribute);
 
$domAttribute = $dom->createAttribute('name');
$domAttribute->value = 'e-mail';
$input->appendChild($domAttribute);
 
$dom->appendChild($input);
 
//如下是输出效果
<input type="text">


五、创建 Table

复制代码 代码如下:

$table = $dom->createElement('table');
 
$domAttribute = $dom->createAttribute('id');
$domAttribute->value = 'my_table';
 
$tr = $dom->createElement('tr');
$table->appendChild($tr);
 
$td = $dom->createElement('td', 'Label');
$tr->appendChild($td);
 
$td = $dom->createElement('td', 'Value');
$tr->appendChild($td);
 
$table->appendChild($domAttribute);
 
$dom->appendChild($table);
 
//如下是输出效果
<table>
    <tbody>
        <tr>
            <td>Label</td>
            <td>Value</td>
        </tr>
    </tbody>
</table>


最后我们来一个完整复杂一点的例子:

复制代码 代码如下:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/87fa2125c70149839032e78c828b811f.html