我想通过按空格键来旋转元素,就像俄罗斯方块效果一样。但到目前为止,我只能旋转一次,而且 position() 方法似乎不像使用键横向移动时那样工作。任何帮助或提示将不胜感激。这是我所拥有的:

$(document).ready(function() {
  $(document).on('keydown', function(e) {
    var keyCode = e.keyCode;
    var div = $("#div");
    e.preventDefault();

    if (keyCode === 37) div.css("left", (div.position().left - 1) + "px");
    if (keyCode === 39) div.css("left", (div.position().left + 1) + "px");
    if (keyCode === 32) div.css('transform','rotate(-90deg)');

});

最佳答案

您的旋转属性始终是 -90px 。我会有一个变量来跟踪从 0 开始的“旋转”。然后在每次空格键时减去 -90。请记住不要超过 360,而是重置回 0。

$(document).ready(function() {
  var rotation = 0;
  $(document).on('keydown', function(e) {
    var keyCode = e.keyCode;
    var div = $("#div");
    e.preventDefault();

    if (keyCode === 37) div.css("left", (div.position().left - 1) + "px");
    if (keyCode === 39) div.css("left", (div.position().left + 1) + "px");
    if (keyCode === 32) {
      rotation -= 90;
      if (rotation < -360)
        rotation = 0;

      div.css('transform','rotate('+rotation+'deg)');
    }
  });
});
#div {
  border: 1px solid #CCC;
  width: 100px;
  height: 50px;
  text-align: center;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="div">test</div>

关于JavaScript/jQuery : rotate element on key press (tetris effect),我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42793438/

10-11 02:40