首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何剪短动画

如何剪短动画
EN

Stack Overflow用户
提问于 2016-01-21 12:49:07
回答 1查看 92关注 0票数 0

我有一个div在js中移动按键事件。在释放键后,它会持续移动一段时间。如何使动画在发布时立即停止?

动画在带有char代码的开关语句中,我可以在开关中使用keyup函数吗?

代码语言:javascript
运行
复制
 $(".sprite2").hide();

    $(document).keydown(function(key) {
        switch(key.which) {

            // a
            case 65:
                $(".sprite2").hide();
                $(".sprite").show();
                $(".sprite").animate({left: "-=10px"}, 'fast');
                $(".sprite2").animate({left: "-=10px"}, 'fast');
                break;

            // w
            case    87:
                $(".sprite").animate({top: "-=10px"}, 'fast');
                $(".sprite2").animate({top: "-=10px"}, 'fast');
                break;

            // d
            case 68:
                $(".sprite2").show();
                $(".sprite").hide();
                $(".sprite2").animate({left: "+=10px"}, 'fast');
                $(".sprite").animate({left: "+=10px"}, 'fast');
        break;

            // s
            case 83:
                $(".sprite").animate({top: "+=10px"}, 'fast');
                $(".sprite2").animate({top: "+=10px"}, 'fast');
                break;

            case onkeyup: 
                $(".sprite").animate()
        }
    });
}); 

'sprite‘是html元素。

我似乎无法让. .add/removeClass工作,因此我通过添加第二个类并隐藏我不想显示的那个来克服这个问题。

他们是一样的,但一个水平反射时,动画向相反的方向(看起来就像向前走)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-01-21 13:02:21

您可以修改div的CSS属性,而不是使用动画。通过添加您希望它按当前位置向下移动的像素数量来更新该位置。

甚至更好。下面是一个使用开关语句在不同按键上按特定方向动画的示例:JQuery实例

来自上述链接的代码:

代码语言:javascript
运行
复制
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>jQuery Move an Element to Left/Right/Up/Down Using Arrow Keys</title>
<style type="text/css">
    .box{
        width: 100px;
        height: 100px;
        position: relative;
        margin: 200px auto 0;
        background: url("../images/mushroom.jpg") yellowgreen;
    }
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script type="text/javascript">
$(document).keydown(function(e){
    switch (e.which){
    case 37:    //left arrow key
        $(".box").finish().animate({
            left: "-=50"
        });
        break;
    case 38:    //up arrow key
        $(".box").finish().animate({
            top: "-=50"
        });
        break;
    case 39:    //right arrow key
        $(".box").finish().animate({
            left: "+=50"
        });
        break;
    case 40:    //bottom arrow key
        $(".box").finish().animate({
            top: "+=50"
        });
        break;
    }
});
</script>
</head>
<body>
    <p><strong>Note:</strong> Click inside the output viewport and press the arrow keys to move the box.</p>
    <div class="box"></div>
</body>
</html>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/34924312

复制
相关文章

相似问题

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