首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >不能使用cancelAnimationFrame。什么都没发生(铬)

不能使用cancelAnimationFrame。什么都没发生(铬)
EN

Stack Overflow用户
提问于 2015-10-10 12:49:07
回答 1查看 1.2K关注 0票数 1

问题:I不能取消由色度识别的cancelAnimationFrame使用的requestAnimationFrame。

我尝试了什么:,我使用了console.log,但是没有显示错误。我console.logged的cancelAnimationFrame和我得到了未定义,而请求对应记录很好。我还尝试了不同版本的cancelAnimationFrame,包括前缀版本:

代码语言:javascript
复制
cancelAnimationFrame
webkitCancelAnimationFrame
window.cancelAnimationFrame etc..

我还试着将取消代码放入函数中,但正如预期的那样,这并不重要。

的问题:,为什么我不能停止我的requestAnimationFrame?取消它是我推荐的吗?

http://jsfiddle.net/p8hv15j4/2/

代码语言:javascript
复制
var elem = document.getElementById('test');
var currentPos = 0;

var requestAnimationFrame = window.requestAnimationFrame || 
                            window.mozRequestAnimationFrame || 
                            window.webkitRequestAnimationFrame || 
                            window.msRequestAnimationFrame;

function fn() {
    currentPos += 5;

    elem.style.left = currentPos + "px";

    if (Math.abs(currentPos) >= 900) {
        currentPos = -500;
    }
        requestAnimationFrame(fn);
}
fn();

setTimeout(function() {
     cancelAnimationFrame(fn);
   }, 1000)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-10 12:52:43

requestAnimationFrame返回一个ID,这是您需要传递给cancelAnimationFrame的内容。

实际上,它的工作方式与set/clearTimeout完全相同--设置它返回一个标识符,然后取消该标识符。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33054175

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档