我想通过按空格键来旋转元素,就像俄罗斯方块效果一样。但到目前为止,我只能旋转一次,而且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)');
});
答案 0 :(得分:3)
您的轮播属性始终为-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)');
}
});
});
&#13;
#div {
border: 1px solid #CCC;
width: 100px;
height: 50px;
text-align: center;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="div">test</div>
&#13;