实现拖拽元素改变元素列表序号列表

参考文档:http://www.sortablejs.com/index.html

我司有需求,拖动列表改变列表排序。

so,尝试了一下。

按照文档介绍,通过npm安装:

npm install sortablejs --save

在react中使用:(仅示例)

import React, { useEffect } from 'react';
// import Sortable from 'react-sortable';
import Sortable from "sortablejs";
import { PageContainer } from '@ant-design/pro-layout';
import style from './style.less'
const testa = () => {
  useEffect(() => {
    new Sortable(document.getElementById('items'), {
      animation: 150,
      ghostClass: 'blue-background-class',
      onUpdate: function (evt) {
        console.log(evt.oldIndex, evt.newIndex);//oldIndex元素原始位置,newIndex元素最新位置
      },
    });
  }, [])
  return (
    <PageContainer title={false}>
      <ul id="items" className={style.example1}>
        <li key="0">a0</li>
        <li key="1">a1</li>
        <li key="2">a2</li>
        <li key="3">a3</li>
        <li key="4">a4</li>
        <li key="5">a5</li>
        <li key="6">a6</li>
      </ul>
    </PageContainer>
  )
}
export default testa

其他有需要用到的方法如下:


                                var sortable = new Sortable(el, {
                                    group: "name",  // or { name: "...", pull: [true, false, 'clone', array], put: [true, false, array] }
                                    sort: true,  // boolean 定义是否列表单元是否可以在列表容器内进行拖拽排序
                                    delay: 0, // number 定义鼠标选中列表单元可以开始拖动的延迟时间;
                                    touchStartThreshold: 0, // px, how many pixels the point should move before cancelling a delayed drag even
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值