2017-09-05 26 views
2
<table> 
<tr> 
    <th>Year</th> 
    <th>Score</th> 
</tr> 
<tr> 
    <td>2014</td> 
    <td>3078</td> 
</tr> 
</table> 

上記のテーブルが変数として正常に格納されている場合、どのようにオーバーフロー-xスタイル属性でdivに追加することができますか?私は次のスニペットが、無葉巻を試してみた2つのDOMDocumentノードをマージする

$div = str_get_html('<div style="overflow-x:auto;"></div>'); 

$div = $div->find('div'); 

$div = $div->appendChild($table); 

return $div; 

ので、予想される出力は次のようになります。この1つはあなたの実装の基本的なアイデアを与えるだろう

<div style="overflow-x:auto;"> 
<table> 
    <tr> 
     <th>Year</th> 
     <th>Score</th> 
    </tr> 
    <tr> 
     <td>2014</td> 
     <td>3078</td> 
    </tr> 
</table> 
</div> 
+0

あなたは以前に同じ質問を投稿しませんか? – Barmar

+0

@ D.Wells予想される出力を共有できますか? –

+0

@Sahil質問に今追加しました –

答えて

1

希望。ここでは、DOMDocumentを使用しています。

Try this code snippet here

<?php 

ini_set('display_errors', 1); 

//creating table node 

$tableNode='<table><tr><th>Year</th><th>Score</th></tr><tr><td>2014</td><td>3078</td></tr></table>'; 

$domDocument = new DOMDocument(); 
$domDocument->encoding="UTF-8"; 
$domDocument->loadHTML($tableNode); 
$domXPath = new DOMXPath($domDocument); 
$table = $domXPath->query("//table")->item(0); 

//creating empty div node. 

$domDocument = new DOMDocument(); 
$element=$domDocument->createElement("div"); 
$element->setAttribute("style", "overflow-x:auto;"); 

$result=$domDocument->importNode($table,true);//importing node from of other DOMDocument 
$element->appendChild($result); 
echo $domDocument->saveHTML($element); 
関連する問題