React如何使用sortablejs實(shí)現(xiàn)拖拽排序
React使用sortablejs實(shí)現(xiàn)拖拽排序
1、使用npm裝包
$ npm install sortablejs --save
2、引入Sortable
import Sortable from "sortablejs";
3、使用方法
<div className="grid-box" ref={this.sortableGroupDecorator}> {menus && menus.map((item, i) => { return this.renderSelectedItemView(item, i); })} </div>
sortableGroupDecorator = componentBackingInstance => { if (componentBackingInstance) { let options = { draggable: ".rows", // animation: "150", onEnd: evt => { let children = evt.to.children; } }; Sortable.create(componentBackingInstance, options); } };
sortablejs之強(qiáng)大的拖拽庫(kù)
Sortable.js是一款優(yōu)秀的js拖拽庫(kù),支持ie9及以上版本ie瀏覽器和現(xiàn)代瀏覽器,也可以運(yùn)行在移動(dòng)觸摸設(shè)備中。
不依賴(lài)jQuery,支持 Meteor、AngularJS、React、Vue、Knockout框架和任何CSS庫(kù),如Bootstrap、Element UI。你可以用來(lái)拖拽div、table等元素。
Sortable.js可以實(shí)現(xiàn)同組內(nèi)上下拖動(dòng)元素,也可以實(shí)現(xiàn)不同組內(nèi)互相拖動(dòng)元素。
安裝
npm i sortablejs -S
基本示例
以下示例基于 Vue2:
<template> <div ref="box"> <div data-id="a">a</div> <div data-id="b">b</div> <div data-id="c">c</div> </div> </template> <script> import Sortable from 'sortablejs'; export default { mounted() { this.$nextTick(function() { this.initSortable(); }); }, methods: { initSortable() { let sortable; // 拖動(dòng)配置 const ops = { animation: 200, group: "name", // 拖動(dòng)結(jié)束 onEnd: function (evt) { // 獲取拖動(dòng)后的排序,arr數(shù)組里的值是 data-id 的順序 let arr = sortable.toArray(); console.log({evt, arr}) }, }; //初始化 sortable = Sortable.create(this.$refs.box, ops); } }, }; </script>
常用配置
const config = { //一個(gè)網(wǎng)頁(yè)存在多個(gè)分組時(shí)設(shè)置,組名相同的組之間元素可以相互拖拽 group: "name", //2種group寫(xiě)法選一種就可以了 group: { name: 'name', pull: 'clone', //克隆元素 }, //是否允許元素內(nèi)部排序,如果為false當(dāng)有多個(gè)排序組時(shí),多個(gè)組之間可以拖拽,本身不能拖拽(默認(rèn)true) sort: true, //是否禁用拖拽和排序 disabled: false, //動(dòng)畫(huà)效果持續(xù)時(shí)間(不設(shè)置或0都沒(méi)有過(guò)渡效果) animation: 150, //點(diǎn)擊指定class類(lèi)的元素才能拖拽(比如點(diǎn)擊元素內(nèi)的圖標(biāo)才能拖拽元素,可以給圖標(biāo)設(shè)置my-handle class) //class可以定義在元素本身上,也可以定義在子元素上 handle: ".my-handle", // class為ignore的元素不能拖動(dòng) filter: ".ignore", //含有item 類(lèi)的元素可以被拖拽(class只能定義在元素本身上) draggable: ".item", //指定獲取拖動(dòng)后排序的屬性 dataIdAttr: 'data-id', //給??课恢锰砑拥腸lass(可以給這個(gè)class定義樣式) ghostClass: "ghost", //選中元素添加的類(lèi)(包括懸浮的元素和停靠位置的元素) chosenClass: "chosen", //拖拽對(duì)象移動(dòng)時(shí)添加的類(lèi) dragClass: "drag", //禁用html5原生拖拽 forceFallback: false, ... //克隆事件 onClone: function (evt) { //被克隆的對(duì)象(被移到另外地方的那個(gè)元素) var origEl = evt.item; //克隆后的對(duì)象(還是在原來(lái)位置的元素) var cloneEl = evt.clone; cloneEl.innerHTML = "clone出的元素"; }, ... }
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解react中的state的簡(jiǎn)寫(xiě)方式
React是一個(gè)狀態(tài)機(jī)主要體現(xiàn)在state上,通過(guò)與用戶(hù)交易實(shí)現(xiàn)不同的狀態(tài),state是組件的私有屬性,是用來(lái)初始化的,本文重點(diǎn)給大家介紹react中的state的簡(jiǎn)寫(xiě)方式,感興趣的朋友一起看看吧2021-08-08淺談React Native Flexbox布局(小結(jié))
這篇文章主要介紹了淺談React Native Flexbox布局(小結(jié)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-01-01react-routerV6版本和V5版本的詳細(xì)對(duì)比
React-Router5是React-Router6的前一個(gè)版本,它已經(jīng)被React-Router6取代,React-Router 6是一次較大的重大更新,本文就來(lái)介紹一下react-routerV6版本和V5版本的詳細(xì)對(duì)比,感興趣的可以了解一下2023-12-12react中的watch監(jiān)視屬性-useEffect介紹
這篇文章主要介紹了react中的watch監(jiān)視屬性-useEffect使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09React?高階組件與Render?Props優(yōu)缺點(diǎn)詳解
這篇文章主要weidajai?介紹了React?高階組件與Render?Props優(yōu)缺點(diǎn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11JavaScript中rem布局在react中的應(yīng)用
這篇文章主要介紹了JavaScript中rem布局在react中的應(yīng)用 的相關(guān)資料,需要的朋友可以參考下2015-12-12