PHP如何使用DOMDocument類生成HTML-創(chuàng)新互聯(lián)

本篇內(nèi)容介紹了“PHP如何使用DOMDocument類生成HTML”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

創(chuàng)新互聯(lián)建站秉承實(shí)現(xiàn)全網(wǎng)價(jià)值營銷的理念,以專業(yè)定制企業(yè)官網(wǎng),做網(wǎng)站、成都做網(wǎng)站,小程序制作,網(wǎng)頁設(shè)計(jì)制作,成都手機(jī)網(wǎng)站制作,營銷型網(wǎng)站建設(shè)幫助傳統(tǒng)企業(yè)實(shí)現(xiàn)“互聯(lián)網(wǎng)+”轉(zhuǎn)型升級(jí)專業(yè)定制企業(yè)官網(wǎng),公司注重人才、技術(shù)和管理,匯聚了一批優(yōu)秀的互聯(lián)網(wǎng)技術(shù)人才,對(duì)客戶都以感恩的心態(tài)奉獻(xiàn)自己的專業(yè)和所長。


 
最近我在查詢 php.net 的時(shí)候,發(fā)現(xiàn) DOMDocument 這個(gè)類非常的有意思, 可以用來生成 XML 或 HTML 文件, DOMDocument 為我們提供了一系列的方法來生成 XML/HTML 標(biāo)簽并插入到 DOM 中, 現(xiàn)在就讓我們來看下如何生成的
 
這里先來看下, 利用它所提供的方法生成的效果, 見下圖:

PHP如何使用DOMDocument類生成HTML

一、創(chuàng)建新的 DOM 文件


復(fù)制代碼 代碼如下:

//實(shí)例化 DOMDocument 類,并指定版本號(hào)
$dom = new DOMDocument('1.0');
 
//將生成的標(biāo)簽或代碼輸出到頁面
echo $dom->saveHTML();


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


復(fù)制代碼 代碼如下:

$css_text = 'p{color:#ff00ff;}';
 
//創(chuàng)建新的 style 標(biāo)簽和 CSS 內(nèi)容
$style = $dom->createElement('style', $css_text);
 
//添加該 style 標(biāo)簽到 DOM 文件中
$dom->appendChild($style);
 
//如下是輸出效果
<style>
    p{color:#ff00ff;}
</style>


這里需要說下就是 createElement 方法, 當(dāng)你想創(chuàng)建 <style> 標(biāo)簽并寫入 Css, 可以利用該方法的第二個(gè)參數(shù)作為 Css 內(nèi)容,如上所示。 但如果你想創(chuàng)建 <br> 標(biāo)簽, 第二個(gè)參數(shù)即可省略, 如下:


復(fù)制代碼 代碼如下:


//創(chuàng)建新的 <br> 標(biāo)簽
$br = $dom->createElement('br');
 
//添加該 <br> 標(biāo)簽到 DOM 文件中
$dom->appendChild($br);


三、為 HTML 元素添加屬性
 
HTML 元素?fù)碛懈鞣N各樣的屬性, 為其添加屬性可以用到 createAttribute() 方法


復(fù)制代碼 代碼如下:


$css_text = 'p{color:#ff00ff;}';
 
//創(chuàng)建新的 style 標(biāo)簽和 CSS 內(nèi)容
$style = $dom->createElement('style', $css_text);
 
//創(chuàng)建新的屬性 'type'
$domAttribute = $dom->createAttribute('type');
 
//為屬性 'type' 添加值
$domAttribute->value = 'text/css';
 
//添加該屬性到 style 標(biāo)簽中
$style->appendChild($domAttribute);
 
//添加該 style 標(biāo)簽到 DOM 文件中
$dom->appendChild($style);
 
//如下是輸出效果
<style type="text/css">
    p{color:#ff00ff;}
</style>

復(fù)制代碼 代碼如下:


$p_text = 'This is a paragraph.';
 
//創(chuàng)建新的 p 標(biāo)簽和內(nèi)容
$p = $dom->createElement('p', $p_text);
 
//創(chuàng)建新的屬性 'id'
$domAttribute = $dom->createAttribute('id');
 
//為屬性 'id' 添加值
$domAttribute->value = 'description';
 
//添加該屬性到 p 標(biāo)簽中
$p->appendChild($domAttribute);
 
//添加該 p 標(biāo)簽到 DOM 文件中
$dom->appendChild($p);
 
//如下是輸出效果
<p id="description">
    某一天
</p>


四、添加 Form 元素
 
添加 textbox


復(fù)制代碼 代碼如下:


$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">


五、創(chuàng)建 Table


復(fù)制代碼 代碼如下:

$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>


最后我們來一個(gè)完整復(fù)雜一點(diǎn)的例子:


復(fù)制代碼 代碼如下:


$dom = new DOMDocument('1.0');
 
//CSS 內(nèi)容
$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;}';
 
//創(chuàng)建新的 style 標(biāo)簽和 CSS 內(nèi)容
$style = $dom->createElement('style', $css_text);
 
//創(chuàng)建新的屬性 'type'
$domAttribute = $dom->createAttribute('type');
 
//為屬性 'type' 添加值
$domAttribute->value = 'text/css';
 
//添加該屬性到 style 標(biāo)簽中
$style->appendChild($domAttribute);
 
//添加該 style 標(biāo)簽到 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 下拉框添加選項(xiàng)
$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如何使用DOMDocument類生成HTML”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

網(wǎng)站標(biāo)題:PHP如何使用DOMDocument類生成HTML-創(chuàng)新互聯(lián)
本文來源:http://bm7419.com/article30/gopso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)網(wǎng)站建設(shè)網(wǎng)站排名、關(guān)鍵詞優(yōu)化、網(wǎng)站營銷、小程序開發(fā)、網(wǎng)站改版

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁設(shè)計(jì)