jer*_*iuh 4 javascript ajax jquery popup
我有一个客户想要在一个居中的弹出窗口中打开各种大小的图像.我试图让他们使用FancyBox,但他们不想要插页式演示,所以...
我最初打开一个通用弹出窗口,根据图像大小重新调整大小和居中onload但他们不喜欢移位所以我添加了一个PHP脚本来回显大小并使用jQuery来获取大小信息以提供给弹出调用.
但似乎这导致的延迟是引发所有弹出窗口拦截器.
这是JS
$("#portfolioBigPic").click(function () {
var src = $("#portfolioBigPic").attr('src');
var ar = src.split('/');
var fname = ar.pop();
fname = '/g/portfolio/clients/big/' + fname;
$.get("imgsize.php", { i: fname}, function(data){
var dim = data.split(",");
popit(fname,dim[0],dim[1]);
});
});
function popit(img,w,h) {
var features = 'width='+w+',height='+h+', toolbar=0, location=0, directories=0, status=0, menubar=0, scrollbars=0, resizable=1,';
var left = (screen.width/2)-(w/2);
var top = 0;
features += 'top='+top+',left='+left;
bigpic = window.open('portfolioBigPic.php?img='+img, 'bigpic',features);
bigpic.focus();
}
Run Code Online (Sandbox Code Playgroud)
躲避阻挡者和失败之间的唯一区别是我添加了AJAX .get并使用它来指定w和h.
有关如何避免这种情况的任何想法?也许我应该使用PHP来获取所有大图片的宽度和高度,并在此页面加载时编写它们的JS数组?我是否正确,因为获取数据导致的延迟使拦截器绊倒?
思考?任何建议都非常感谢.
JG
//编辑 - 添加我的解决方案Per Spiky的答案我需要将popit()调用移出AJAX调用的成功处理程序,以便调用发生在用户的click事件的上下文中.
所以我意识到当点击我的小拇指来设置大图像的预览(#portfolioBigPic)时,我可以在那时查找完整大小的图片.所以我将AJAX大小向上移动到拇指的click().
HTH有人.
这不是造成问题的延迟本身,而是你试图从脚本执行上下文打开窗口,而不是"点击"处理程序.具体来说,在这种情况下,它是AJAX成功处理程序(或其他).
您无法解决该限制,所以是的,您应该首先将图像大小转储到主页面,以便处理"点击"的脚本可以知道大小.