vue2.0使用Sortable.js实现的拖拽功能

简介

在使用vue1.x之前的版本的时候,页面中的拖拽功能,我在项目中是直接用的jquery ui中的sortable.js,只是在拖拽完成后,在update的回调函数中又重新排序了存放数据的数组。但是当把vue升级到2.0以上后发现拖拽功能失效了,于是使用了下面代码。

该案例主要是在用于vuejs2.0中实现的拖拽功能,用到的的js有Sortable.js,vuedraggable.js,当然还有vue.min.js,提供的案例使用的require.js加载。

实现效果

实现后的效果如图所示:

html主要代码

<draggable :list="list2" :move="getdata" @update="datadragEnd" :options="{animation: 300,handle:'.dargDiv'}">
        <transition-group name="list-complete" >
            <div v-for="element in list2" :key="element.it.name"  class="list-complete-item">
                <div class="styleclass dargDiv">{{element.id}}</div>
                <div class="styleclass">{{element.it.name}}</div>

            </div>
        </transition-group>
    </draggable>
    

css代码

body{
    font-family:'微软雅黑'
}
[v-cloak]{
    display:none;
}
#example{
    width:1000px;
    margin:0 auto;
}
.list-complete-item {
  transition: all 1s;
    height:50px;
    line-height: 50px;
    background: #000;
    color:#fff;
    text-align: center;
    font-size:24px;
    margin-top:10px;
}
.styleclass{
    width:100px;
    float:left;
}
.list-complete-enter, .list-complete-leave-active {
  opacity: 0;
  height: 0px;
  margin-top: 0px;
  padding: 0px;
  border: solid 0px;
}
.list-complete-sortable-chosen,.list-complete-sortable-ghost{
 opacity: 0;
  height: 0px;
  margin-top: 0px;
  padding: 0px;
  border: solid 0px;
}
.dargDiv{
    cursor:move;
    background:red;
}
.wrods{
    margin-top:50px;
}
p{
    line-height:24px;
    text-align:center;
}

js代码

require(['vue','vuedraggable'],function(Vue,draggable){
    Vue.component('draggable', draggable);
     new Vue({
        el: '#example',
        data: {
           list2:[
           {id:"id1",it:{name:'bbbb'}},
           {id:"id2",it:{name:'2222'}},
           {id:"id3",it:{name:'3333'}},
           {id:"id4",it:{name:'4444'}}
           ]
        },
        methods:{
            getdata: function(evt){
                console.log(evt.draggedContext.element.id);
            },
            datadragEnd:function(evt){
                console.log('拖动前的索引:'+evt.oldIndex);
                console.log('拖动后的索引:'+evt.newIndex);

            }

        }
    })

})

里面的可配置的很多细节请参考参考地址,这里不做详细介绍。
可下载案例地址:https://github.com/hxlmqtily1... 
参考地址:https://github.com/SortableJS...

### Vue2使用 Sortable.js 实现 Element UI 的 el-table 组件拖动行功能并保持序号不变 为了在 Vue2 项目中通过 `Sortable.js` 实现 `el-table` 行拖拽排序的功能,同时确保表格中的序号不会因拖拽而改变,可以按照以下方式实现。 #### 主要思路 1. 使用 `Sortable.js` 提供的 API 来监听拖拽事件。 2. 在数据模型层面更新数组顺序以同步视图变化。 3. 添加一个独立字段用于存储原始索引值,在渲染时利用该字段来显示固定的序号[^1]。 以下是具体实现: ```javascript <template> <div> <el-table :data="tableData" border style="width: 100%"> <!-- 定义一列表格序号 --> <el-table-column type="index" label="#" width="50"></el-table-column> <el-table-column prop="name" label="名称" width="180"></el-table-column> <el-table-column prop="age" label="年龄"></el-table-column> </el-table> <!-- 可选:添加一个隐藏 DOM 节点作为 Sortable 初始化目标 --> <tr ref="dragHandle" class="hidden-drag-handle"> <td></td><td></td><td></td> </tr> </div> </template> <script> import Sortable from 'sortablejs'; export default { data() { return { tableData: [ { name: '张三', age: 24 }, { name: '李四', age: 30 }, { name: '王五', age: 27 } ] }; }, mounted() { this.initSortable(); }, methods: { initSortable() { const elTableBody = this.$refs.dragHandle || document.querySelector('.el-table__body-wrapper tbody'); new Sortable(elTableBody, { animation: 150, handle: '.handle', // 如果有自定义手柄类名,则在此指定 onEnd: (evt) => { const oldIndex = evt.oldIndex; const newIndex = evt.newIndex; // 更新数据源顺序 const movedItem = this.tableData.splice(oldIndex, 1)[0]; this.tableData.splice(newIndex, 0, movedItem); } }); } } }; </script> <style scoped> .hidden-drag-handle { display: none; /* 隐藏辅助节点 */ } .handle { cursor: move; /* 自定义手柄样式 */ } </style> ``` #### 关键点解析 - **初始化 Sortable** 将 `Sortable.create()` 方法绑定到 `.el-table__body-wrapper tbody` 上,这是实际承载表格主体的部分。如果需要更精确的选择器,可以通过 `$refs` 或者动态查询获取对应的 DOM 元素。 - **onEnd 回调函数** 当用户完成拖拽操作后触发此回调。通过调整原生 JavaScript 数组的方法(如 `splice`),重新排列内部的数据结构,从而让前端展示的内容与逻辑一致[^1]。 - **固定序号处理** 利用 `<el-table-column>` 的内置属性 `type="index"` 自动生成基于当前页面分页后的连续编号;或者手动维护额外的一个字段记录初始位置,并将其映射至界面层面上呈现给用户的视觉效果。 --- ####
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值