<!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>
div{width:100px;height:100px;background: red;position: absolute}
span{position: absolute;left:300px;top:0;background: #000;width:1px;height:100px;}
</style>
</head>
<body>
<div></div>
<span></span>
<script>
var oDiv = document.getElementsByTagName('div')[0];
var timer = null
oDiv.onclick = function(){
startMove(this,300)
}
function startMove(dom,target){
clearInterval(timer)
var a = 3
var iSpeed = 0;
var u = 0.8
timer = setInterval(function(){
a = (target - dom.offsetLeft)/5
iSpeed += a;
iSpeed *= 0.8;
if(Math.abs(iSpeed)<1&&Math.abs(target-dom.offsetLeft)<1){
clearInerval(timer);
dom.style.left = target+'px'
}else{
dom.style.left=dom.offsetLeft+iSpeed+'px'
}
},30)
}
</script>
</body>
</html>