- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在创建一个幻灯片,它将在计时器上运行(由进度条显示),但允许用户单击箭头以强制执行下一步。我正在尝试尽可能多地使用 CSS3,因此对于我的循环计时器,我正在使用进度条的 CSS3 动画。
它的工作方式是,我从 width:0
开始我的进度条,并将其设置为 width:100%;
。它具有 5s
的 CSS3 transition
。然后我观察动画的结束,并用它来调用我的 resetprogress
和 changeimage
函数,之后我再次开始播放。它无限循环。
我创建了一个简化的 jsFiddle 来展示我在说什么: http://jsfiddle.net/a3H9L/
简化版的代码如下。如您所见,我调用了 startProgress
,在其中我通过更改宽度启动 CSS3 动画,然后为所述动画的结束设置观察器,此时我重置并重新开始。
startProgress();
function startProgress() {
$('div').width('100%');
$('div').one('webkitTransitionEnd otransitionend oTransitionEnd msTransitionEnd transitionend',function(e){
resetProgress();
startProgress();
});
}
function resetProgress (){
$('div').addClass('notransition'); // Disable transitions
$('div').width('0');
$('div')[0].offsetHeight; // Trigger a reflow, flushing the CSS changes
$('div').removeClass('notransition'); // Re-enable transitions
}
$('button').click(function(event){
resetProgress();
startProgress();
});
我的问题是,如果用户单击重置(最终将是下一个和上一个),我该如何在重置和开始新循环之前打破原来的循环?现在,我认为我正在开始一个新循环而不结束原始循环,这让我同时运行两个循环。
编辑:我认为有问题的原因是,当我点击重置几次时,循环中的事情开始在其他时间发生,除了进度重置时。
最佳答案
长话短说:
在链接你的 .one()
之前简单地调用一个 .off()
让我们使用您的 fiddle 进行实验。
实验 1:
每次调用 .one()
函数时使用控制台记录一条简单消息:
$('div').one('...', function(e) {
console.log('one called!');
resetProgress();
startProgress();
});
观察:
是的,你是对的,它们是叠加的!如果您单击该按钮,则会添加更多 .one()
函数,并且会在条到达动画末尾时同时触发。一旦动画完成以下和后续时间,所有这些仍会触发!
即:运行 fiddle,点击你的按钮五次。第一个动画完成后,控制台记录 6 条消息 (5 + 1)。条形图会自行重置并产生另外 6 条消息。这是六的倍数。
实验 2:
现在,让我们尝试在函数开始时关闭自身:
$('div').one('...', function(e) {
$(this).off(e);
console.log('one called!');
resetProgress();
startProgress();
});
观察:
这并没有产生我们预期的抵消效果。与第一个实验相同的结果。
实验 3:
让我们尝试关闭所有处理程序(通过省略“e”):
$('div').one('...', function(e) {
$(this).off();
console.log('one called!');
resetProgress();
startProgress();
});
观察:
所有排队的 .one()
处理程序在动画结束时执行,但它们在运行一次后自行终止,并且不会在下一次动画完成时触发。
实验 4:
您真正想要做的是在设置新处理程序之前取消所有先前排队的处理程序。那么让我们这样做:
$('div').off().one('...', function(e) {
console.log('one called!');
resetProgress();
startProgress();
});
观察:
这就是你的答案!该函数现在运行一次,因为在放置新的处理程序之前取消设置以前的处理程序。在链接您的 .one()
.off()
免责声明:
这些实验假设这些是您元素上唯一的事件处理程序。如果您有通过 .on()
、.one()
或类似设置的其他处理程序,而不是使用 .off()
来清除所有内容,您必须指定要清除的处理程序,如下所示:
.off('webkitTransitionEnd otransitionend oTransitionEnd msTransitionEnd transitionend')
关于javascript - jQuery 取消先前排队的事件处理程序以重新启动 CSS 动画,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24959123/
我正在尝试将 WPF CodeBehid 事件(如 Event、Handler、EventSetter)转换为 MVVM 模式。我不允许使用 System.Windows.Controls,因为我使用
我可能误解了 Backbone 中的事件系统,但是当我尝试以下代码时什么也没有发生。当我向 Backbone.Events 扩展对象添加新属性时,它不应该触发某种更改、更新或重置事件吗?就像模型一样吗
我遇到了一个简单的问题,就是无法弄清楚为什么它不起作用。我有一个子组件“app-buttons”,其中我有一个输入字段,我想听,所以我可以根据输入值过滤列表。 如果我将输入放在我有列表的根组件中,一切
System.Timers.Timer 的 Elapsed 事件实际上与 System.Windows.Forms.Timer 的 Tick 事件相同吗? 在特定情况下使用其中一种比使用另一种有优势吗
嗨,这个 javascript 代码段是什么意思。(evt) 部分是如此令人困惑.. evt 不是 bool 值。这个怎么运作? function checkIt(evt) { evt
我正在使用jquery full calendar我试图在事件被删除时保存它。 $('calendar').fullCalendar ({
我有两个链接的鼠标事件: $('body > form').on("mousedown", function(e){ //Do stuff }).on("mouseup", function(
这是我的代码: $( '#Example' ).on( "keypress", function( keyEvent ) { if ( keyEvent.which != 44 ) {
我尝试了 dragOver 事件处理程序,但它没有正常工作。 我正在研究钢琴,我希望能够弹奏音符,即使那个键上没有发生鼠标按下。 是否有事件处理程序? 下面是我正在制作的钢琴的图片。 最佳答案 您应该
当悬停在相邻文本上时,我需要使隐藏按钮可见。这是通过 onMouseEnter 和 onMouseLeave 事件完成的。但是当点击另外的文本时,我需要使按钮完全可见并停止 onMouseLeave
我有ul标签内 div标签。我申请了mouseup事件 div标记和 click事件 ul标签。 问题 每当我点击 ul标签,然后都是 mouseup和 click事件被触发。 我想要的是当我点击 u
我是 Javascript 和 jQuery 的新手,所以我有一个非常愚蠢的疑问,请耐心等待 $(document).click(function () { alert("!"); v
我有一个邮政编码解析器,我正在使用 keyup 事件处理程序来跟踪输入长度何时达到 5,然后查询服务器以解析邮政编码。但是我想防止脚本被不必要地调用,所以我想知道是否有一种方法可以跟踪 keydown
使用事件 API,我有以下代码来发布带有事件照片的事件 $facebook = new Facebook(array( "appId" => "XXX", "se
首次加载 Microsoft Word 时,既不会触发 NewDocument 事件也不会触发 DocumentOpen 事件。当 Word 实例已打开并打开新文档或现有文档时,这些事件会正常触发。
我发现了很多相关问题(这里和其他地方),但还没有具体找到这个问题。 我正在尝试监听箭头键 (37-40) 的按键事件,但是当以特定顺序使用箭头键时,后续箭头不会生成“按键”事件。 例子: http:/
给定的 HTML: 和 JavaScript 的: var $test = $('#test'); $test.on('keydown', function(event) { if (eve
我是 Node.js 的新手,希望使用流运行程序。对于其他程序,我必须同时启动一个服务器(mongodb、redis 等),但我不知道我是否应该用这个运行一个服务器。请让我知道我哪里出了问题以及如何纠
我正在尝试使用 Swift 和 Cocoa 创建一个适用于 OS X 的应用程序。我希望应用程序能够响应关键事件,而不将焦点放在文本字段上/文本字段中。我在 Xcode 中创建了一个带有 Storyb
我有以下代码: (function(w,d,s,l,i){ w[l]=w[l]||[];w[l].push({
我是一名优秀的程序员,十分优秀!