为了账号安全,请及时绑定邮箱和手机立即绑定

键盘控制div移动,为什么向右比向左快得多?向下比向上快得多?

键盘控制div移动,为什么向右比向左快得多?向下比向上快得多?

开心每一天1111 2019-03-13 18:15:22
        var oDiv = document.getElementById('div1'),            ev = ev || event;        document.onkeydown = function (ev) {            var pos=getPos(oDiv);            switch (ev.keyCode) {                case 37:                    oDiv.style.left = oDiv.offsetLeft - 10 + 'px';                    break;                case 38:                    oDiv.style.top = oDiv.offsetTop - 10 + 'px';                    break;                case 39:                    oDiv.style.left = oDiv.offsetLeft + 10 + 'px';                    break;                case 40:                    oDiv.style.top = oDiv.offsetTop + 10 + 'px';                    break;                       }        }                  刚刚找到原因了,因为我把div的定位设置成relative,后来改成absolute上下左右移动的速度就一样了.....请教各位,这个是为什么?有什么关系吗     再试了一下发现,即使position:relative下,把body的margin和padding值都设置为0的话,四个移动方向的速度是一样的~可我还是不知道为什么o(╥﹏╥)o     
查看完整描述

1 回答

?
郎朗坤

TA贡献1921条经验 获得超9个赞

看了一下。好像是style.leftoffsetLeft不相等的原因。
你把父元素的内外边距都设置为0应该就没问题了。

查看完整回答
反对 回复 2019-03-27
  • 1 回答
  • 0 关注
  • 323 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号