ajax load 设置同步,Jquery:在ajax load()之后运行脚本

我正在使用load()函数通过单击菜单中的按钮从不同页面动态获取详细信息。其中一个按钮指向使用自己的jquery效果的图像库。但那些脚本没有运行。我尝试使用getscript()显式加载它们,但这也不起作用。这是代码:

$(document).ready(function() {

var hash = window.location.hash.substr(1);

var href = $('#nav li a').each(function(){

var href = $(this).attr('href');

if((hash==href.substr(0,href.length-4))&&(hash!='')){

var toLoad = hash+'.php #content';

$('#content').load(toLoad);

}

});

$('#nav li a').click(function(){

var toLoad = $(this).attr('href')+' #content';

$('#content').hide();

window.location.hash = $(this).attr('href').substr(0,$(this).attr('href').length-4);

$('#content').load(toLoad,showNewContent());

function showNewContent() {

$('#content').fadeIn(1000);

$.getScript("gallery.js");

}

return false;

});

});

这是我的gallery.js文件的内容。确切的效果可能无关紧要,我已粘贴下面的代码来显示我的警报框的位置:

$(document).ready(function(){

//perform actions when DOM is ready

var z = 0; //for setting the initial z-index's

var inAnimation = false; //flag for testing if we are in a animation

alert("1");

$('#pictures img').each(function() { //set the initial z-index's

z++; //at the end we have the highest z-index value stored in the z variable

$(this).css('z-index', z); //apply increased z-index to

alert("2");

});

function swapFirstLast(isFirst) {

if(inAnimation) return false; //if already swapping pictures just return

else inAnimation = true; //set the flag that we process a image

var processZindex, direction, newZindex, inDeCrease; //change for previous or next image

alert("3");

if(isFirst) { processZindex = z; direction = '-'; newZindex = 1; inDeCrease = 1; } //set variables for "next" action

else { processZindex = 1; direction = ''; newZindex = z; inDeCrease = -1; } //set variables for "previous" action

$('#pictures img').each(function() { //process each image

alert("4");

if($(this).css('z-index') == processZindex) { //if its the image we need to process

$(this).animate({ 'top' : direction + $(this).height() + 'px' }, 'slow', function() { //animate the img above/under the gallery (assuming all pictures are equal height)

$(this).css('z-index', newZindex) //set new z-index

.animate({ 'top' : '0' }, 'slow', function() { //animate the image back to its original position

inAnimation = false; //reset the flag

});

});

} else { //not the image we need to process, only in/de-crease z-index

$(this).animate({ 'top' : '0' }, 'slow', function() { //make sure to wait swapping the z-index when image is above/under the gallery

$(this).css('z-index', parseInt($(this).css('z-index')) + inDeCrease); //in/de-crease the z-index by one

});

}

});

return false; //don't follow the clicked link

}

$('#next1 a').click(function() {

alert("5");

return swapFirstLast(true); //swap first image to last position

});

$('#prev1 a').click(function() {

alert("6");

return swapFirstLast(false); //swap last image to first position

});

});

//Function for z-index based gallery ends here

这是我发现的:

我执行ctrl + F5并从开始加载页面,然后单击图库按钮。我得警报“1”。图像加载,但动画无效。

我再次单击图库按钮,没有刷新,我从1到6收到所有适当的警报,效果就像一个魅力。

当效果不起作用时,我只需将gallery.js的内容放在chrome-console中,然后点击回车,效果再次完美。

此外,有时候虽然完全重复上述步骤,但效果不起作用。这可能是什么问题?我听说getscript方法是异步的,我甚至尝试设置ajax同步,但我仍然得到不可预知的结果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值