在这一章节里, 我们来了解下如何利用核心(core) PHP 生成 HTML 文件
最近我在查询 php.net 的时候,发现 DOMDocument 这个类非常的有意思, 可以用来生成 XML 或 HTML 文件, DOMDocument 为我们提供了一系列的方法来生成 XML/HTML 标签并插入到 DOM 中, 现在就让我们来看下如何生成的
这里先来看下, 利用它所提供的方法生成的效果, 见下图:
一、创建新的 DOM 文件
//实例化 DOMDocument 类,并指定版本号 $dom = new DOMDocument('1.0'); //将生成的标签或代码输出到页面 echo $dom->saveHTML();
$css_text = 'p{color:#ff00ff;}'; //创建新的 style 标签和 CSS 内容 $style = $dom->createElement('style', $css_text); //添加该 style 标签到 DOM 文件中 $dom->appendChild($style); //如下是输出效果 <style> p{color:#ff00ff;} </style>
//创建新的 <br> 标签 $br = $dom->createElement('br'); //添加该 <br> 标签到 DOM 文件中 $dom->appendChild($br);
$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 id="description"> 某一天 </p>
$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 = $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'); $formAttribute->value = 'post'; $form->appendChild($formAttribute); //添加 table $table = $dom->createElement('table'); $tableAttribute = $dom->createAttribute('id'); $tableAttribute->value = 'my_table'; $table->appendChild($tableAttribute); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $th = $dom->createElement('th', 'Generate HTML using PHP'); $tr->appendChild($th); $thAttribute = $dom->createAttribute('colspan'); $thAttribute->value = '2'; $th->appendChild($thAttribute); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $td = $dom->createElement('td', 'First Name'); $tr->appendChild($td); //添加新的列(column) $td = $dom->createElement('td'); $tr->appendChild($td); //添加 input 元素到列(column)中 $input = $dom->createElement('input'); $td->appendChild($input); $tdAttribute = $dom->createAttribute('type'); $tdAttribute->value = 'text'; $input->appendChild($tdAttribute); $tdAttribute = $dom->createAttribute('name'); $tdAttribute->value = 'f_name'; $input->appendChild($tdAttribute); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $td = $dom->createElement('td', 'Email'); $tr->appendChild($td); //添加新的列(column) $td = $dom->createElement('td'); $tr->appendChild($td); //添加 input 元素到列(column)中 $input = $dom->createElement('input'); $td->appendChild($input); $tdAttribute = $dom->createAttribute('type'); $tdAttribute->value = 'text'; $input->appendChild($tdAttribute); $tdAttribute = $dom->createAttribute('name'); $tdAttribute->value = 'e-mail'; $input->appendChild($tdAttribute); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $td = $dom->createElement('td', 'Gender'); $tr->appendChild($td); //添加新的列(column) $td = $dom->createElement('td'); $tr->appendChild($td); //添加 input 元素到列(column)中 $select = $dom->createElement('select'); $td->appendChild($select); $tdAttribute = $dom->createAttribute('name'); $tdAttribute->value = 'gender'; $select->appendChild($tdAttribute); //为 Select 下拉框添加选项 $opt = $dom->createElement('option', 'Male'); $domAttribute = $dom->createAttribute('value'); $domAttribute->value = 'male'; $opt->appendChild($domAttribute); $select->appendChild($opt); $opt = $dom->createElement('option', 'Female'); $domAttribute = $dom->createAttribute('value'); $domAttribute->value = 'female'; $opt->appendChild($domAttribute); $select->appendChild($opt); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $td = $dom->createElement('td', 'Interest'); $tr->appendChild($td); //添加新的列(column) $td = $dom->createElement('td'); $tr->appendChild($td); //添加 input 元素到列(column)中 $radio = $dom->createElement('input'); $td->appendChild($radio); $radAttribute = $dom->createAttribute('type'); $radAttribute->value = 'radio'; $radio->appendChild($radAttribute); $radAttribute = $dom->createAttribute('name'); $radAttribute->value = 'interest'; $radio->appendChild($radAttribute); $radAttribute = $dom->createAttribute('id'); $radAttribute->value = 'php'; $radio->appendChild($radAttribute); $label = $dom->createElement('label', 'PHP'); $labelAttribute = $dom->createAttribute('for'); $labelAttribute->value = 'php'; $label->appendChild($labelAttribute); $td->appendChild($label); $radio = $dom->createElement('input'); $td->appendChild($radio); $radAttribute = $dom->createAttribute('type'); $radAttribute->value = 'radio'; $radio->appendChild($radAttribute); $radAttribute = $dom->createAttribute('name'); $radAttribute->value = 'interest'; $radio->appendChild($radAttribute); $radAttribute = $dom->createAttribute('id'); $radAttribute->value = 'jquery'; $radio->appendChild($radAttribute); $label = $dom->createElement('label', 'jQuery'); $labelAttribute = $dom->createAttribute('for'); $labelAttribute->value = 'jquery'; $label->appendChild($labelAttribute); $td->appendChild($label); //添加新的行(row) $tr = $dom->createElement('tr'); $table->appendChild($tr); //添加新的列(column) $td = $dom->createElement('td'); $tr->appendChild($td); $tdAttribute = $dom->createAttribute('colspan'); $tdAttribute->value = '2'; $td->appendChild($tdAttribute); //添加 input 元素到列(column)中 $input = $dom->createElement('input'); $td->appendChild($input); $tdAttribute = $dom->createAttribute('type'); $tdAttribute->value = 'submit'; $input->appendChild($tdAttribute); $tdAttribute = $dom->createAttribute('value'); $tdAttribute->value = 'Sign-Up'; $input->appendChild($tdAttribute); //添加 table 到 form 中 $form->appendChild($table); echo $dom->saveHTML();
本文向大家介绍使用PHP的HTML DOMDocument解析HTML,包括了使用PHP的HTML DOMDocument解析HTML的使用技巧和注意事项,需要的朋友参考一下 可以通过以下代码获取<div>标记内的<div>标记内的文本,其中<div>内的class =“ main”内- 示例 输出结果 这将产生以下输出-
问题内容: 我想使用PHP DOMDocument更改标签属性的值。 例如,假设我们有以下这行HTML: 我将上述代码加载到PHP中,如下所示: 我想使用PHP的DOMDocument扩展名将“ href”值更改为“ http://google.com/”。这可能吗? 与往常一样感谢您的帮助! 问题答案:
问题内容: 这里的PHP解析有点新,但是我似乎无法让PHP的DomDocument返回显然是可识别的节点。加载的HTML将来自“ .net”,因此不一定能保证XML的合规性,但我尝试以下操作: 尽管我没有收到任何错误,但我仅收到以下内容作为输出: 我应该无法查找标签,因为它确实具有ID吗? 问题答案: 该手册解释了为什么: 为了使此功能起作用,您将需要使用DOMElement->setIdAttr
本文向大家介绍php生成zip文件类实例,包括了php生成zip文件类实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php生成zip文件类。分享给大家供大家参考。具体如下: 希望本文所述对大家的php程序设计有所帮助。
问题内容: 我正在尝试获取HTML文档中包含以下文本模式的元素:#\ S {11} 因此,前者将通过使用以下内容进行匹配: 结果将是这样的: 我可以获取所有匹配的文本(请参见上面的行)。但是我希望文本的父元素匹配,因此我可以将其用作遍历文档树的起点。在这种情况下,我希望所有h2元素都返回,而不是文本匹配。 有想法吗? 问题答案: 印刷品:
本文向大家介绍Python 生成VOC格式的标签实例,包括了Python 生成VOC格式的标签实例的使用技巧和注意事项,需要的朋友参考一下 常用目标检测模型基本都是读取的PASCAL VOC格式的标签,下面代码用于生成VOC格式的代码,根据需要修改即可: 补充知识: python对PASCAL VOC标注数据进行统计 用于统计训练数据中的类别,以及所有目标的个数: 以上这篇Python 生成VOC