sortable 拖拽排序,获取排序后的数据

问题:

使用sortable排序时,页面元素虽然重新排序了,但是真实的数组数据并没有排序,还是原来的顺序,但是如果排序时同时修改数组,会造成排序的昏乱

解决:

主要思路: 将数组的里的每条数据的id 赋给table元素的class上,这样获取排序后的元素,就能拿到由数组id组成的新数组,并且还是页面上排序后的顺序,然后再根据id的排序将原数组排序,得到排序后的新数组

1、 sortable 排序之后可以获取到最新的排序的元素 evt.to.rows

sortable 拖拽排序,获取排序后的数据_第1张图片

2、table一定要加上 row-key !!!

sortable 拖拽排序,获取排序后的数据_第2张图片

 3、把数组中每条数据的id(唯一不重复值)赋给row-class-name

4、每次排序结束后拿到由id组成的正确顺序的数组

this.sortable = Sortable.create(el, {
          onEnd(evt) {
              if (evt.newIndex != evt.oldIndex) {
                console.log(evt)
                self.videoListarr = []
                Array.from(evt.to.rows).forEach(item => {
                  console.log(item.className.split(' ')[1])
                  self.videoListarr.push(item.className.split(' ')[1])
                })
              }
            }
          });

5、最后提交时,根据id顺序给原数组排序,得到排序后的新数组

let arrvideo = {};
              this.videoList.map((item)=>{
                let index = this.videoListarr.indexOf(item.lessonNumberId);
                arrvideo[index]= item;
            })

arrvideo的key是顺序,值是数据

sortable 拖拽排序,获取排序后的数据_第3张图片

你可能感兴趣的:(排序算法,算法,html)