<div class=".items"> <div class="item"><div class="sort"></div> <div class="item"><div class="sort"></div> </div> <style> .items { /* * 该对象必须设置postion为相对或绝对定位,因为被拖动的对象定位是absolute * 如果容器没有positin的话,拖动时对象就会相对于最外层有position的元素来显示位置 */ position: relative; } </style> <script> Array.prototype.move = function (findex, tindex) { this.splice(tindex, 0, this.splice(findex, 1)[0]); } // 启用拖动排序 $('.items').sortable({ items: '.item', handle: '.sort', axis: 'y', // 限制在Y轴方向拖动 containment: '.items', // 限制在.item容器内拖动,一般不用设置,设置了反而会导致拖动时移动不灵活,特别很难把元素拖动到最后一个元素下面,除非容器底部有比较大的间隙可容纳一个元素 start: (event, ui) => { ui.item.attr('sort', ui.item.index()); }, update: (event, ui) => { var fSort = ui.item.attr('sort'); var tSort = ui.item.index(); items.move(fSort, tSort); for (var i = tSort; i < items.length; i++) { items[i].sort = i; } for (var i = tSort - 1; i > -1; i--) { items[i].sort = i; } ui.item.removeAttr('sort'); } }); </script>