首页 > 编程 > PHP > 正文

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

2020-03-22 19:08:45
字体:
来源:转载
供稿:网友

最近我在查询 php.net 的时候,发现 DOMDocument 这个类非常的有意思, 可以用来生成 XML 或 HTML 文件, DOMDocument 为我们提供了一系列的方法来生成 XML/HTML 标签并插入到 DOM 中, 现在就让我们来看下如何生成的

这里先来看下, 利用它所提供的方法生成的效果, 见下图:一、创建新的 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- html' target='_blank'>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 id="description"
某一天
/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" name="e-mail"
五、创建 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 id="my_table"
tbody
tr
td Label /td
td Value /td
/tr
/tbody
/table
最后我们来一个完整复杂一点的例子:
复制代码 代码如下:
$dom = new DOMDocument('1.0');

//CSS 内容
$css_text = '';
$css_text .= 'body{width:285px;margin:auto;margin-top:50px;}';
$css_text .= '#my_table{border:1px solid #ececec;}';
$css_text .= '#my_table th{border:1px solid #ececec;padding:5px;text-decoration:underline;}';
$css_text .= '#my_table td{border:1px solid #ececec;padding:5px;}';
$css_text .= '#my_table td:first-child{text-align:right;color:#333333;font-weight:bold;color:#999999;}';

//创建新的 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);

//添加 form
$form = $dom- createElement('form');
$dom- appendChild($form);
$formAttribute = $dom- createAttribute('method');

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表