
小程序流程是甚么_Vue完成拖放排序功用的实例代码
2021-01-07
凡科抠图:下面看下vue 拖拽排序的实例代码,具体代码如下所示:
template section div div 拖动排序 /div div draggable="true" v-for="list in data1" :data-id="list.id" @dragstart="dragstartEvent" @dragend="dragendEvent" @dragenter="dragenterEvent" @dragleave="dragleaveEvent" @dragover="dragoverEvent" {{list.title}} /div /div /section /template script export default { data() { return { dragElement: null, lock: true, data1: [ {id: 1, title: '这里是列表1的标题'}, {id: 2, title: '这里是列表2的标题'}, {id: 3, title: '这里是列表3的标题'}, {id: 4, title: '这里是列表4的标题'}, {id: 5, title: '这里是列表5的标题'}, {id: 6, title: '这里是列表6的标题'}, {id: 7, title: '这里是列表7的标题'} data2: [ {id: 1, title: '这里是列表11的标题'}, {id: 2, title: '这里是列表12的标题'}, {id: 3, title: '这里是列表13的标题'}, {id: 4, title: '这里是列表14的标题'} methods: { dragstartEvent(ev) { const self = this; self.dragElement = ev.target; ev.target.style.backgroundColor = '#f8f8f8'; dragendEvent(ev) { ev.target.style.backgroundColor = '#fff'; ev.preventDefault(); dragenterEvent(ev) { const self = this; if(self.dragElement != ev.target){ ev.target.parentNode.insertBefore(self.dragElement, ev.target); dragleaveEvent(ev) { const self = this; if(self.dragElement != ev.target){ if(self.lock (ev.target == ev.target.parentNode.lastElementChild || ev.target == ev.target.parentNode.lastChild)){ ev.target.parentNode.appendChild(self.dragElement); self.lock = false; }else{ self.lock = true; dragoverEvent(ev) { ev.preventDefault(); /script style scoped .drag-box-left{ float: left; width: 45%; .drag-box-right{ float: right; width: 45%; .drag-list{ border: 1px solid #ddd; padding:10px; margin-bottom: 20px; transition: border .3s; .drag-list:hover{ border: 1px solid #20a0ff; .drag-title{ font-weight: 400; line-height: 25px; margin: 10px 0; font-size: 22px; color: #1f2f3d; /style
总结
以上所述是小编给大家介绍的Vue实现拖放排序功能的实例代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对凡科网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
扫描二维码分享到微信