关于鼠标拖拽的问题

半夜三更看球 2019-03-27 04:15:50
关于拖拽的提问
在练习JavaScript拖拽的时候突然发现使用style.left和style.top会影响第二次的鼠标拖拽,希望各位大牛解释一下这是什么原理? 请看下列代码

```
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<style>
.onc {
width: 150px;
height: 150px;
background-color: red;
position: absolute;
left: 0px;
top: 0px;
}
</style>
</head>
<body>
<div class="onc"></div>
</body>
<script>
var div = document.getElementsByTagName("div")[0];
var disX,
disY;
div.onmousedown = function (e) {
var event = e ||window.event;//解决兼容性问题
disX = e.clientX - div.offsetLeft;//此处为什么不能用div.style.left
disY = e.clientY - div.offsetTop;//此处为什么不能用div.style.top
document.onmousemove = function (e) {
div.style.left = e.clientX - disX + "px";
div.style.top = e.clientY - disY + "px";
}
document.onmouseup = function (e) {
document.onmousemove = null;
document.onmouesup = null;
}
}
</script>

</html>
```
...全文
93 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
天际的海浪 2019-03-27
  • 打赏
  • 举报
回复
第一。div.style.left只能获取div元素style属性中设置的内联样式,无法获取<style></style>样式表设置的样式。所以第一次取div.style.left的值是 "" 空字符串。 第二。div.style.left获取的值是一个字符串,并且带有px之类的单位。如: "200px" ,不好直接用于数值运算。而offsetLeft获取的就是数值,方便直接用于数值运算。
槿畔 2019-03-27
  • 打赏
  • 举报
回复
因为你的style.left就是css的内联样式而已,始终值并没有改变,一直都是0,,,你再次拖拽,,,,相当于e.clientX - 0

87,910

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧