console
var node=document.querySelector("#container");
var draging=null;
node.ondragstart = function(event){
console.log("start:")
event.dataTransfer.setData("te", event.target.innerText)
draging = event.target
}
node.ondragover = function(event){
console.log("over:")
event.preventDefault()
var target = event.target
if(target.nodeName === "LI" && target !== draging){
var targetRect = target.getBoundingClientRect()
var dragingRect = draging.getBoundingClientRect()
if (target) {
if (target.animated) {
return;
}
}
if(_index(draging) < _index(target)){
target.parentNode.insertBefore(draging, target.nextSibling)
} else {
target.parentNode.insertBefore(draging, target)
}
_animate(dragingRect, draging)
_animate(targetRect, target)
}
}
function _index(el){
var index = 0
if(!el || !el.parentNode){
return -1
}
while(el && (el = el.previousElementSibling)){
index++
}
return index
}
function _animate(prevRect, target){
var ms = 300
if(ms) {
var currentRect = target.getBoundingClientRect()
if(prevRect.nodeType === 1) {
prevRect = prevRect.getBoundingClientRect()
}
_css(target, 'transition', 'none')
_css(target, 'transform', 'translate3d(' +
(prevRect.left - currentRect.left) + 'px,' +
(prevRect.top - currentRect.top) + 'px,0)'
);
target.offsetWidth;
_css(target, 'transition', 'all ' + ms + 'ms');
_css(target, 'transform', 'translate3d(0,0,0)');
clearTimeout(target.animated);
target.animated = setTimeout(function() {
_css(target, 'transition', '');
_css(target, 'transform', '');
target.animated = false;
}, ms);
}
}
function _css(el, prop, val){
var style = el && el.style
if(style){
if(val === void 0){
if(document.defaultView && document.defaultView.getComputedStyle){
val = document.defaultView.getComputedStyle(el, '')
}else if(el.currentStyle){
val = el.currentStyle
}
return prop === void 0 ? val : val[prop]
} else {
if(!(prop in style)){
prop = '-webkit-' + prop;
}
style[prop] = val + (typeof val === 'string' ? '' : 'px')
}
}
}
<div>
<ul id="container">
<li class="ele" draggable="true">1</li>
<li class="ele" draggable="true">2</li>
<li class="ele" draggable="true">3</li>
<li class="ele" draggable="true">4</li>
<li class="ele" draggable="true">5</li>
<li class="ele" draggable="true">6</li>
<li class="ele" draggable="true">7</li>
<li class="ele" draggable="true">8</li>
</ul>
</div>
ul {
list-style: none;
margin-left:200px;
font-size: 0;
}
.ele {
font-size: 16px;
width: 100px;
height: 40px;
border: 1px solid #999;
background: #EA6E59;
margin: 2px 0;
border-radius: 10px;
padding-left: 10px;
color: white;
cursor: move;
}