追加后的 jQuery 回调
我有以下代码:
HTML
<div id="body"></div>
JS
var site = { 'pageData' : [
{
'loadInTo' : '#aboutUs',
'url' : 'aboutUs.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#whatWeDo',
'url' : 'whatWeDo.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#ourValues',
'url' : 'ourValues.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#ourExpertise',
'url' : 'ourExpertise.html',
'urlSection' : '.sectionInner'
}
]}
for(i=0; i < site.pageData.length; i++) {
var loader = site.pageData[i];
$('#body').append('<div id="'+ loader.loadInTo +'" class="section" />');
$(loader.loadInTo).load(loader.url + ' ' + loader.urlSection);
}
我正在做的是循环访问 site 变量并使用 jQuery 的追加方法写出一些 div,这些方法在“loadInTo”中设置了 id,这工作得很好。完成此操作后,我想使用 jQuery 的 load 方法用其他页面的 HTML 填充 div。添加div后是否有回调?像这样的东西:
$('#body').append('<div id="'+ loader.loadInTo +'" class="section" />', function(){
$(loader.loadInTo).load(loader.url + ' ' + loader.urlSection);
});
I have the following code:
HTML
<div id="body"></div>
JS
var site = { 'pageData' : [
{
'loadInTo' : '#aboutUs',
'url' : 'aboutUs.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#whatWeDo',
'url' : 'whatWeDo.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#ourValues',
'url' : 'ourValues.html',
'urlSection' : '.sectionInner'
},
{
'loadInTo' : '#ourExpertise',
'url' : 'ourExpertise.html',
'urlSection' : '.sectionInner'
}
]}
for(i=0; i < site.pageData.length; i++) {
var loader = site.pageData[i];
$('#body').append('<div id="'+ loader.loadInTo +'" class="section" />');
$(loader.loadInTo).load(loader.url + ' ' + loader.urlSection);
}
What I am doing is looping through the site variable and writing out some div's using jQuery's append method that have the id set in 'loadInTo', this works fine. After this is complete I want to use jQuery's load method to populate the divs with HTML from other pages. Is there a to make a callback after appending the div's? something like this:
$('#body').append('<div id="'+ loader.loadInTo +'" class="section" />', function(){
$(loader.loadInTo).load(loader.url + ' ' + loader.urlSection);
});
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
jQuery 不支持
.append
的回调。此外,附加效率更高立即获取数据,而不是为每个元素调用.append
。请参阅下面的代码。每个要追加的元素都会添加到一个字符串中。字符串完成后,将添加标记,并附加 HTML。然后,轮询器被激活,检查 DOM 中是否存在
marker
元素。如果存在,则清除轮询器,删除标记,然后执行代码。更新:设置 ID 时使用
.substr(1)
,因为 ID 不应以#
为前缀。jQuery doesn't support a callback for
.append
. Also, it's much more efficient to append the data at once, rather than calling.append
for each element. See the code below.Every element-to-append is added to a string. Once the string has finished, a marker is added, and the HTML is appended. Then, a poller is activated, checking whether the
marker
element exist in the DOM. If it exists, the poller is cleared, the marker is removed, and the code executes.Update:
.substr(1)
is used when the ID is set, because the ID shouldn't be prefixed by#
.为什么要回调?
$(...).append()
是异步调用吗? 我认为不是,那么为什么不再写一条语句呢?如果您想要避免代码复制,您可以在临时变量中创建新的除法:
createDiv 函数可能如下所示
Why a callback? Is
$(...).append()
an asynchronous call? I think not, so why not just write another statement?If what you're after is avoiding code-replication, you may create the new division in a temporary variable:
Where the createDiv function may look like
在 jquery 中,您可以在附加内容代码之后使用 $() 。这样,您可以确保在对附加内容执行任何任务之前内容已加载并且 DOM 已准备好。
$() 调用一个函数,该函数要么注册 DOM 就绪回调(如果将函数传递给它),要么从 DOM 返回元素(如果将选择器字符串或元素传递给它)
您可以在此处找到更多信息
jQuery 中 $ 和 $() 之间的区别
http://api.jquery.com/ready/
In jquery you could use $() just after your appending contents code. This way you can be sure that the content is loaded and the DOM is ready before performing any tasks on the appended content.
$() calls a function that either registers a DOM-ready callback (if a function is passed to it) or returns elements from the DOM (if a selector string or element is passed to it)
You can find more here
difference between $ and $() in jQuery
http://api.jquery.com/ready/