我正在使用
Jquery加载,然后一旦内容加载到div我想将一些标签更改为语言相关变量.
我的问题是我必须使用settimeout让脚本等待足够长的时间才能准备好编辑元素.
当我使用回调函数参数时,我想要编辑的元素显然没有准备好,因为它们没有被设置.我讨厌使用settimeout,因为这会将每个人限制在最慢的设置,并且总是某些连接会比这更慢.
显然回调方法只是意味着ajax方法得到了html,但它并不能确保导入的元素在dom中实际就绪.
有人有想法吗?
目前的代码
$("#content-basket").load("/BasketPage.htm?time=" + now.getMilliseconds());
...
...
setTimeout("timedbasket();", 500);
...
...
function timedbasket() {
alert($('#basketlegend'));
$('#basketlegend').html(basketlabel);
}
我希望能够使用
$("#content-basket").load("/BasketPage.htm?time=" + now.getMilliseconds(), "", timedbasket());
这是basket.htm源码
<tr>
<td>
<div id="basket">
<fieldset>
<legend><span id="basketlegend"></span></legend>
<table id="baskettbl" border="0" class="basket-table">
<tbody>
<tr class='total'>
<td>
<span id="empty"></span>
</td>
</tr>
</tbody>
</table>
</fieldset>
</div>
</td>
</tr>
最佳答案 使用callback参数进行加载并将代码放入回调中.
$("#content-basket").load("/BasketPage.htm?time=" + now.getMilliseconds(),null,
function() {
...do stuff here after #content-basket is finished loading...
});
在查看jQuery之后,确实看起来响应是在调用任何回调之前注入的,因此应该更新DOM.您是否有可能重新使用可能引用之前存在的DOM元素但被负载替换的jQuery对象?