在动画结束之前调用函数
Function is recalled before end of animation
function seite(j, element, callback){
if (j==0) {$(element).css({"visibility": "hidden"});};
var ele = $(element).eq(j), str = ele.text(), progress = 0;
ele.text('');
$(element).eq(j).css({"visibility": "visible"});
var timer = setInterval(function() {
ele.text(str.substring(0, ++progress));
if (progress >= str.length){
clearInterval(timer);
if (j==$(element).length) {
callback();
};
$('body').animate({
scrollTop: ($(element).eq(j).offset().top)
},500);
seite(j+1, element, callback);
}
}, 10);
}
这就像同一类元素的打字机一样。问题是在动画结束之前调用seite()
,因此动画永远不会停止和滞后。
问题(显示在您自己的答案中(不是延迟回调(它仍然立即运行(。
您需要将调用包装到您的回调中,以匿名函数。
试试这个:
$('body').animate({
scrollTop: ($(element).eq(j).offset().top),
done: function(){ seite(j+1, element, callback); }
},500);
或
$('body').animate({
scrollTop: ($(element).eq(j).offset().top)
},500, function(){ seite(j+1, element, callback); });
找到解决方案(简单的语法错误(:
function seite(i, element, callback) {
window.j = i;
if (window.j == 0) {
$(element).css({
"visibility": "hidden"
});
};
var ele = $(element).eq(window.j),
str = ele.text(),
progress = 0;
ele.text('');
$(element).eq(window.j).css({
"visibility": "visible"
});
var timer = setInterval(function () {
ele.text(str.substring(0, ++progress));
if (progress >= str.length) {
clearInterval(timer);
if (window.j == $(element).length) {
callback();
} else {
$('body').animate({
scrollTop: ($(element).eq(window.j).offset().top),
}, {
duration: 500,
complete: function () {
seite(window.j + 1, element, callback);
}
});
}
}
}, 10);
}
相关文章:
- 如何从模块链中调用函数.导出到节点中
- 调用函数内部的函数
- 在javascript中调用c函数
- DropDownListFor赢得't在更改时调用函数
- Javascript页面调用函数
- 在动画结束之前调用函数
- 允许父窗口在其不同域的子iframe上调用函数
- 运行Infinite Scroll后调用函数时出现问题
- JavaScript:在调用函数的文本输入上按enter键
- 使用大括号和不使用bracs调用函数的区别
- javascript在事件上调用函数
- 从index.html调用函数,该函数无限循环
- 从带参数的字符串变量调用函数中的函数
- 为什么 JS 不在滚动时调用函数
- 是否可以在不更改上下文的情况下调用函数.apply
- 如何在ES6类中使用参数调用函数
- AngularJS:调用函数时编号不更新
- JavaScript中的立即调用函数表达式(IIFE)-传递jQuery
- 在JavaScript中调用函数时自定义此选项
- 调用函数中声明的变量