Vue implements the drag and drop sorting function of the page div box

Vue implements the drag and drop sorting function of the page div box

vue implements the drag and drop sorting function of the div box on the page. Foreword: There are many plug-ins and methods on the market that implement the drag and drop sorting function. This section will not go into details, but only talk about one method: the transition-group method of css3

Effect picture:

1. Use in DOM:

    <transition-group class="container" name="sort">
        <div class="app-item" v-for="app in customApps" :key="app.id" :draggable="true"
            @dragstart="dragstart(app)"
            @dragenter="dragenter(app,$event)"
            @dragend="getDragend(customApps, 'customer', $event)">
            <div>
                <img class="icon_a" v-if="app.logo" :src="app.logo" >
                <div class="ellipsis" >{{app.name}}</div>
            </div>
        </div>
    </transition-group>

2. Define data in data

    import { APi } from '@/api/enterpriseAPi'
    <script>
        export default {
            data() {
                return {
                    oldData: [],
                    newData: [],
                    customApps: [],
                    dragStartId: '',
                    dragEndId: ''
                }
            }
        }
    </script>

3. Use in methods

    dragstart(value) {
        this.oldData = value
        this.dragStartId = value.id
    },
    dragenter(value) {
        this.newData = value
        this.dragEndId = value.id
    },
    getDragend(listData, type) {
            if (this.oldData !== this.newData) {
                let oldIndex = listData.indexOf(this.oldData)
                let newIndex = listData.indexOf(this.newData)
                let newItems = [...listData]
                // Delete the previous DOM node newItems.splice(oldIndex, 1)
                // Add a new DOM node at the end of the drag target newItems.splice(newIndex, 0, this.oldData)
                // After each drag is completed, the data processed by the drag is assigned to the original array, the DOM view is updated, and the page displays the drag animation this.customApps = newItems
                // Call the interface to save data every time the drag ends Api(this.dragStartId, this.dragEndId).then((res) => {})
            }
        },

Drag completion animation style:

    <style lang="scss" scoped>
        .sort-move {
            transition: transform 1s;
        }
    </style>

This is the end of this article about how to use vue to implement the drag and sort function of div boxes on the page. For more related vue div box drag and sort content, please search for previous articles on 123WORDPRESS.COM or continue to browse the related articles below. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Vue implements the function of dragging and sorting lists
  • Vue implements selection, dragging and sorting effects based on vuedraggable
  • vue drag component vuedraggable API options to achieve mutual drag and sorting between boxes
  • Implementing smooth transition drag and drop sorting function based on Vue
  • Use Vue-draggable component to implement drag and drop sorting of table contents in Vue project
  • vue.draggable realizes the drag and drop sorting effect of the table
  • vuedraggable+element ui realizes the drag and drop sorting effect of page controls
  • Detailed explanation of how to use vuedraggable, a drag-and-drop sorting plugin for Vue

<<:  Comprehensive analysis of optimistic locking, pessimistic locking and MVCC in MySQL

>>:  How to use domestic image warehouse for Docker

Recommend

Summary of MySQL 8.0 Online DDL Quick Column Addition

Table of contents Problem Description Historical ...

Vue implements login jump

This article example shares the specific code of ...

Vue imports Echarts to realize line scatter chart

This article shares the specific code of Vue impo...

Detailed explanation of nodejs built-in modules

Table of contents Overview 1. Path module 2. Unti...

Solve the problem of Mac Docker x509 certificate

question Recently I needed to log in to a private...

vue cli3 implements the steps of packaging by environment

The vue project built with cli3 is known as a zer...

W3C Tutorial (1): Understanding W3C

W3C, an organization founded in 1994, aims to unl...

Tutorial diagram of using Jenkins for automated deployment under Windows

Today we will talk about how to use Jenkins+power...

SQL Practice Exercise: Online Mall Database Product Category Data Operation

Online shopping mall database-product category da...

Web Design Summary

<br />From the birth of my first personal pa...

VSCode+CMake+Clang+GCC environment construction tutorial under win10

I plan to use C/C++ to implement basic data struc...

Detailed explanation of docker visualization graphics tool portainer

Table of contents 1. Introduction to Portainer 2....