jquery 如何终止函数?
写了个函数Scroll(),里面有setTimeout反复调用函数的本身,想在鼠标移上时终止,移出时又执行,代码如何写?obj.hover(function(){Scro...
写了个函数Scroll(),里面有setTimeout反复调用函数的本身,想在鼠标移上时终止,移出时又执行,代码如何写?
obj.hover(function(){ Scroll(); 终止这个函数如何写?(setTimeout反复调用执行)
}, function(){ Scroll(); //再执行 }); } 展开
obj.hover(function(){ Scroll(); 终止这个函数如何写?(setTimeout反复调用执行)
}, function(){ Scroll(); //再执行 }); } 展开
5个回答
推荐于2017-10-05 · 知道合伙人金融证券行家
关注
展开全部
1、如果终止一个函数的用return即可,实例如下:
function testA(){
alert('a');
alert('b');
alert('c');
}
testA(); 程序执行会依次弹出'a','b','c'。
function testA(){
alert('a');
return;
alert('b');
alert('c');
}
testA(); 程序执行弹出'a'便会终止。
2、在函数中调用别的函数,在被调用函数终止的同时也希望调用的函数终止,实例如下:
function testC(){
alert('c');
return;
alert('cc');
}
function testD(){
testC();
alert('d');
}
testD(); 可以看到在testD中调用了testC,在testC中想通过return把testD也终止了,事与愿违return只终止了testC,程序执行会依次弹出'c','d'。
function testC(){
alert('c');
return false;
alert('cc');
}
function testD(){
if(!testC()) return;
alert('d');
}
testD(); 两个函数做了修改,testC中返回false,testD中对testC的返回值做了判断,这样终止testC的同时也能将testD终止,程序执行弹出'c'便会终止。
function testA(){
alert('a');
alert('b');
alert('c');
}
testA(); 程序执行会依次弹出'a','b','c'。
function testA(){
alert('a');
return;
alert('b');
alert('c');
}
testA(); 程序执行弹出'a'便会终止。
2、在函数中调用别的函数,在被调用函数终止的同时也希望调用的函数终止,实例如下:
function testC(){
alert('c');
return;
alert('cc');
}
function testD(){
testC();
alert('d');
}
testD(); 可以看到在testD中调用了testC,在testC中想通过return把testD也终止了,事与愿违return只终止了testC,程序执行会依次弹出'c','d'。
function testC(){
alert('c');
return false;
alert('cc');
}
function testD(){
if(!testC()) return;
alert('d');
}
testD(); 两个函数做了修改,testC中返回false,testD中对testC的返回值做了判断,这样终止testC的同时也能将testD终止,程序执行弹出'c'便会终止。
展开全部
var t; //首先你要定义一个全局变量
function Scroll(){ //假设这个就是你的函数Scroll()
t = setTimeout(function(){
Scroll(); //这里就是每两秒反复调用函数的本身
},2000);
}
$obj.hover(function(){
cleartimeout(t); //鼠标移上去就终止之前给T赋值的setTimeout
},function(){
Scroll(); //鼠标移走就重新执行Scroll()函数,当然setTimeout也重新执行
});
function Scroll(){ //假设这个就是你的函数Scroll()
t = setTimeout(function(){
Scroll(); //这里就是每两秒反复调用函数的本身
},2000);
}
$obj.hover(function(){
cleartimeout(t); //鼠标移上去就终止之前给T赋值的setTimeout
},function(){
Scroll(); //鼠标移走就重新执行Scroll()函数,当然setTimeout也重新执行
});
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
使用return ;或者return false;来终止函数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
obj.hover(function(){clearInterval(t)}, function(){t = setTimeout(Scroll,1000);});
更多追问追答
追问
好像不行啊
追答
换成setInterval呢?
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以使用clearTimeout() 方法可取消由 setTimeout() 方法设置的 timeout。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询