1

如果标题令人困惑,我很抱歉,这里是解释:

假设我们有远程页面remotesite.com/page1.html,我们使用该功能file_get_contents获取其源,然后我们使用DOMDocument编辑此源,然后将其打印到我们的页面

$url = "remotesite.com/page1.html";
$html = file_get_contents($url);
$doc = new DOMDocument(); // create DOMDocument
libxml_use_internal_errors(true);
$doc->loadHTML($html); // load HTML you can add $html
//here we do some edits to remove or add contents

我想在打印之前将下面的 Div 添加到内容中:

<div style="float: right; padding-right: 2px;"><a class="open_event_tab" target="_blank" href="some-hard-coded-text-here_'+content+'_title_'+lshtitle+'_event_'+id+'.html" >open event</a></div> 

这是我尝试过的,但软编码部分('+content+'_title_'+lshtitle+'_event_'+id+'href不起作用

我知道我下面的代码可能看起来很愚蠢,但抱歉我没有足够的 php 知识

function createDivNode($doc) {
$divNode = $doc->createElement('div');
$divNode->setAttribute('style', 'float: right; padding-right: 2px;');
$aNode = $doc->createElement('a', 'openEvent');
$aNode->setAttribute('class', 'open_event_tab');
$aNode->setAttribute('target', '_blank');
$aNode->setAttribute('href', 'some-hard-coded-text-here_'+content+'_title_'+lshtitle+'_event_'+id+'.html');
$divNode->appendChild($aNode);
return $divNode;

}

我想遍历从远程站点获得的源代码,以获取每个td看起来像下面的内容,并在关闭它之前添加 div

  <td colspan="2">
     <b>Video </b> 
     <span class="section">Sports</span><b>: </b> 
     <span id="category466" class="category">Motor Sports</span>

    //here i want to add my div
</td>

6 小时的研究,由于我正处于学习阶段,所以我无法弄清楚,所以我决定在这个有用的社区问人

4

2 回答 2

1

现在仍然对你的问题感到困惑,但我认为,你想在其中添加/附加一个动态divtd如果是这种情况,那么你可以试试这个(至少,你会得到一个想法,而且它很干净)

var content = 'someContent', lshtitle = 'someTitle', id = 'anId';
var attr = {
    'class' : 'open_event_tab',
    'target' : '_blank',
    'href' : 'some-hard-coded-text-here_' + content + '_title_' + lshtitle + '_event_' + id + '.html',
    'text' : 'open event'
};
var link = $('<a/>', attr);
var div = $('<div/>', { 'style' : 'float:right;padding-right:2px;' }).append(link);

$('#myTable td').append(div);

演示。

更新:(问题令人困惑,所以下面给出了更新的答案)

只需下载Simple HTML DOM Perser和(此处的文档

    include('simple_html_dom.php');
    $html = file_get_html('remotesite.com/page1.html');
    foreach($html->find('table td') as $td) {
        $td->innertext = $td->innertext . '<div>New Div</div>';
    }

另外,只修改td那些有class=category

    foreach($html->find('table td.category') as $td) {
        $td->innertext = $td->innertext . '<div>New Div</div>';
    }

你完成了。注意<div>New Div</div>,这只是一个示例,希望您可以根据需要进行制作。

该示例的可能结果:

<table>
    <tbody>
        <tr>
            <td colspan="2">
                <b>Video </b> <span class="section">Sports</span><b>: </b> <span id="category466" class="category">Motor Sports</span>
                <div>New Div</div>
           </td>
        </tr>
        <tr>
            <td colspan="2">
                <b>Video </b> <span class="section">Sports</span><b>: </b> <span id="category466" class="category">Motor Sports</span>
                <div>New Div</div>
            </td>
        </tr>
    </tbody>
</table>
于 2013-08-01T23:10:56.980 回答
0

查询

如果要在每个 td 的末尾插入 div,请使用 append()

$('td').append('<div>Test</div>'); 

在每个 td 的开头使用 prepend

$('td').prepend('<div>Test</div>');

欲了解更多信息jquery 网站

于 2013-08-01T22:52:47.673 回答