我在jQuery标签布局中有一个iframe。我正在使用iframe上传图像,以模拟AJAX文件上传。似乎每当我的iframe回发时,它都会导致父页面的$(document).ready执行,重置我所在的当前标签。
关于如何防止这种情况的任何想法?
function uploadDone() {
var data = eval("("+ $('#upload_target').contents().find('body').html() +")");
if(data.success) {
$('#upload_summary').append("<img src='" + data.full_path + "' />");
$('#upload_summary').append("<br />Size: " + data.file_size + " KB");
}
else if(data.failure) { //Upload failed - show user the reason.
alert("Upload Failed: " + data.failure);
}
}
$(document).ready(function() {
$('#image_uploader').submit(function() {
if($.browser.safari || $.browser.opera) {
$('#upload_target').load(function(){
setTimeout(uploadDone, 0);
});
var iframe = document.getElementById('upload_target');
var iSource = iframe.src;
iframe.src = '';
iframe.src = iSource;
} else {
$('#upload_target').load(uploadDone);
}
});
});
答案 0 :(得分:1)
旗帜有意义(正如SolutionYogi所提到的那样)。如果父框架中的document.ready只需执行一次,则将全局标志设置为一个值,您可以在再次触发时检查该值。
另一种方法是在执行后取消绑定document.ready。
例如。 $(document).unbind('ready')