https://github.com/Alex-fun/vue-drag-and-drop-list
  
  
    🐴 Vue directives for modifying lists with the HTML5 drag & drop API.  
    https://github.com/Alex-fun/vue-drag-and-drop-list
  
html5-drag vue
        Last synced: 6 months ago 
        JSON representation
    
🐴 Vue directives for modifying lists with the HTML5 drag & drop API.
- Host: GitHub
- URL: https://github.com/Alex-fun/vue-drag-and-drop-list
- Owner: hejianxian
- License: mit
- Created: 2016-08-25T15:10:26.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2017-08-25T02:34:50.000Z (about 8 years ago)
- Last Synced: 2025-04-19T12:34:33.397Z (6 months ago)
- Topics: html5-drag, vue
- Language: JavaScript
- Homepage: https://hejx.herokuapp.com/vue-dndl/#!/
- Size: 740 KB
- Stars: 331
- Watchers: 24
- Forks: 54
- Open Issues: 2
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE
 
Awesome Lists containing this project
- awesome-github-vue - vue-drag-and-drop-list - 创建排序列表的Vue指令 (UI组件)
- awesome-github-vue - vue-drag-and-drop-list - 创建排序列表的Vue指令 (UI组件)
- awesome-vue - vue-drag-and-drop-list - fun/vue-drag-and-drop-list?style=social) - 创建排序列表的Vue指令 (UI组件)
- awesome - vue-drag-and-drop-list - 创建排序列表的Vue指令 (UI组件)
README
          # vue-drag-and-drop-list  []()
> Vue directives that allow you to build sortable lists with the native HTML5 drag & drop API. Supports nested lists for building trees and other fancy structures.
### 😮 Now support 2.0, see [vddl](https://github.com/hejianxian/vddl) 👏👏 
## Demo
* [Nested Containers](https://hejx.herokuapp.com/vue-dndl/#!/)
* [Simple Lists](https://hejx.herokuapp.com/vue-dndl/#!/simple)
* [Typed Lists](https://hejx.herokuapp.com/vue-dndl/#!/item-types)
* [Drag Handler](https://hejx.herokuapp.com/vue-dndl/#!/handler)
* [Horizontal Items](https://hejx.herokuapp.com/vue-dndl/#!/horizontal)
## Not supported VueJS 2.0
[Directive interface change](https://github.com/vuejs/vue/issues/2873)
In general, in 2.0 directives have a greatly reduced scope of responsibility: they are now only used for applying low-level direct DOM manipulations. In most cases, you should prefer using Components as the main code-reuse abstraction.
**✌️This mean it should be a component. You can view [vddl](https://github.com/hejianxian/vddl)**.
## Supported browsers
IE9+ and all modern browsers are supported.
**Touch devices are not supported**, because they do not implement the HTML5 drag & drop standard. However, you can use a [shim](https://github.com/timruffles/ios-html5-drag-drop-shim) to make it work on touch devices as well.
## Installation
```bash
npm install vue-drag-and-drop-list --save
```
or
```bash
yarn add vue-drag-and-drop-list
```
## Usage
```js
import Vue from 'vue';
import vueDragAndDropList from 'vue-drag-and-drop-list';
Vue.use(vueDragAndDropList);
```
or include as an inline script.
## Required CSS styles
Both the dnd-list and it's children require relative positioning, so that the directive can determine the mouse position relative to the list and thus calculate the correct drop position.
```css
ul[dnd-list], ul[dnd-list] > li {
    position: relative;
}
```
## Wiki
you should read the [Vue directive doc](http://vuejs.org/guide/custom-directive.html) first.
* [dnd-draggable](https://github.com/Alex-fun/vue-drag-and-drop-list/wiki/dnd-draggable)
* [dnd-list](https://github.com/Alex-fun/vue-drag-and-drop-list/wiki/dnd-list)
* [dnd-nodrag](https://github.com/Alex-fun/vue-drag-and-drop-list/wiki/dnd-nodrag)
* [dnd-handle](https://github.com/Alex-fun/vue-drag-and-drop-list/wiki/dnd-handle)
## Development
```bash
npm install
npm run watch // rollup watch
npm run build //rollup -c
```
## Run Demo
```bash
cd demo
// vue project
npm install
npm run dev // webpack
```
See all demos source code in 'views/*.vue' file.
## Thanks
[angular-drag-and-drop-lists](https://github.com/marceljuenemann/angular-drag-and-drop-lists)
## License
MIT