我在 HTML 页面上有以下内容:
<script type="text/javascript">
setInterval(function(){refresh()},5000);
function refresh()
{
$.post("test.php",
{
// nothing here
},
function(data, textStatus)
{
$('' + data + '').find('.maindiv').each(function () {
$('.maindiv').replaceWith('.maindiv');
});
});
}
</script>
<div id = "1" class= "maindiv">
<div sid= "1" class= "subdiv">old sub div content</div>
<div cid= "1" class= "childdiv">another old sub div</div>
<img id = "1" src="http://foo.com/bar.png"/>
</div>
<div id = "2" class= "maindiv">
<div sid= "2" class= "subdiv">this content is old</div>
<div cid= "2" class= "childdiv">please update me!</div>
<img id= "2" src="http://foo.com/bar.png"/>
</div>
被调用以更新元素的 PHP 页面 (test.php):
<?php
echo '<div id = "1" class= "maindiv">
<div sid= "1" class= "subdiv">this is new sub div</div>
<div cid= "1" class= "childdiv">this is also new sub div content</div>
<img id= "1" src="http://foo.com/bar.png"/>
</div>';
echo '<div id = "2" class= "maindiv">
<div sid= "2" class= "subdiv">new content</div>
<div cid= "2" class= "childdiv">new content for this child div</div>
<img id= "2" src="http://foo.com/bar.png"/>
</div>';
?>
这两个元素也出现在 HTML 页面上。基本上我想调用 PHP 页面并从 PHP 页面获取这些元素并在 HTML 页面的响应中循环遍历它们,并将每个 maindiv(包括其所有子元素)替换为 HTML 页面上的相应元素。
这只是一个非常基本的例子。我这样做是因为这些元素中的内容发生了变化,并且想要替换像实时更新这样的元素。
我发布的功能似乎没有响应,所以不知道如何实现这一点。
提前致谢