react-anything-sortable
is a ReactJS component that can sort anyother component passed as this.props.children
. It is compatible with IE8 and all modern browsers.
You can check the straight-forward demo by examining index.jsx
, or here's a brief demo.
In your_component.jsx
var React = require('react');
var Sortable = require('react-anything-sortable');
var YourSortableItem = require('./YourItem');
React.renderComponent(
<Sortable>
<YourItem/>
<YourItem/>
</Sortable>
, document.body);
and in YourItem.jsx
var React = require('react');
var SortableItemMixin = require('react-anything-sortable/SortableItemMixin');
var YourItem = React.createClass({
mixins: [SortableItemMixin],
render: function(){
return this.renderWithSortable(
<div>your item</div>
);
}
});
- specify your style for
Sortable
andSortable Items
, checkstyle.css
- don't forget the
this.renderWithSortable
call inYourItem.jsx
- specify
sortData
inYourItem.jsx
so thatSortable
can return the sorted array - add
onSort
props toSortable
to be noticed when a sort operation finished - since we can't track any children modification in
Sortable
, you have to usekey
to force updateSortable
when adding/removing children.