<!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>
*{
margin:0;list-style: none;padding:0
}
ul{
position: relative;
margin:100px auto 0px;
width:800px;
height:200px;
}
ul li.ele{
float:left;
border:1px solid black;
background: orange;
height:98px;
width:198px;
line-height: 98px;
text-align: center;
}
ul li.bg{
position: absolute;
left:0px;
top:0;
width:200px;
height:100px;
opacity: .4;
background: deeppink;
}
</style>
</head>
<body>
<ul>
<li class="ele">4234</li>
<li class="ele">4324</li>
<li class="ele">432</li>
<li class="bg"></li>
</ul>
<script>
var oLiArray = document.getElementsByTagName('li');
var oLiBg = oLiArray[oLiArray.length-1];
for(var i = 0;i<oLiArray.length-1;i++){
oLiArray[i].onmouseenter = function(){
startMove(oLiBg,this.offsetLeft)
}
}
var timer = null
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>