Vue에서 목록 정렬 및 드래그 정렬을 구현하는 방법은 무엇입니까?

PHPz
풀어 주다: 2023-06-25 09:59:01
원래의
7433명이 탐색했습니다.

프런트 엔드 개발 기술이 지속적으로 발전함에 따라 점점 더 많은 웹사이트와 애플리케이션이 인터페이스에 드래그 앤 드롭 정렬 기능을 구현해야 합니다. Vue 프레임워크에서는 일부 라이브러리나 구성 요소를 사용하여 목록 정렬 및 드래그 정렬 기능을 쉽게 구현할 수 있습니다.

1. sortable.js를 사용하여 목록 정렬 구현

sortable.js는 목록의 드래그 앤 드롭 정렬 기능을 지원할 수 있는 독립 라이브러리입니다. Vue.js에서는 sortable.js를 사용하여 목록의 정렬 기능을 구현합니다.

먼저 프로젝트에 sortable.js를 설치해야 합니다. npm 명령을 사용하여 설치할 수 있습니다.

npm install sortablejs --save
로그인 후 복사

그런 다음 구성 요소에 sortable.js를 도입합니다.

import Sortable from 'sortablejs'
로그인 후 복사

그런 다음 구성 요소의 마운트된 후크 기능에서 아래와 같이 sortable.js를 사용하여 목록을 초기화합니다.

mounted() {
  let el = this.$refs.list
  this.sortable = Sortable.create(el, {
    onEnd: this.onEnd
  })
},
methods: {
  onEnd: function (evt) {
    // 拖动后的排序操作
  }
}
로그인 후 복사

그 중 onEnd는 목록 항목을 드래그 앤 드롭할 때의 콜백 함수입니다. 이 함수에서는 목록 순서를 재정렬하거나 재배열된 목록 순서를 저장할 수 있습니다. 데이터베이스나 서버에.

2. vue-draggable을 사용하여 드래그 정렬 구현

vue-draggable은 Vue.js 기반의 드래그 가능한 정렬 목록 컴포넌트로, 목록의 드래그 앤 드롭 정렬 기능을 쉽게 구현할 수 있습니다. vue-draggable을 사용하여 Vue.js 애플리케이션에서 테이블 행 드래그, 타일 크기 및 위치 변경 등과 같은 대화형 목록을 구현합니다.

npm 명령을 사용하여 vue-draggable을 설치할 수 있습니다:

npm install vuedraggable --save
로그인 후 복사

그런 다음 아래와 같이 구성 요소에서 vue-draggable 구성 요소를 사용합니다.

<template>
  <draggable v-model="list" :element="'ul'">
    <li v-for="item in list" :key="item.id">
      {{ item.id }}. {{ item.text }}
    </li>
  </draggable>
</template>

<script>
  import draggable from 'vuedraggable'

  export default {
    components: { draggable },
    data() {
      return {
        list: [
          { id: 1, text: 'Vue.js' },
          { id: 2, text: 'React.js' },
          { id: 3, text: 'Angular.js' },
          { id: 4, text: 'Ember.js' },
          { id: 5, text: 'Backbone.js' },
          { id: 6, text: 'Knockout.js' }
        ]
      }
    }
  }
</script>
로그인 후 복사

위 코드에서는 vue-draggable 구성 요소를 사용하여 v-model 지시어는 컴포넌트의 목록 데이터를 바인딩하는 데 사용되므로 드래그를 통해 목록의 순서를 변경할 수 있습니다.

3. Vue Sortable을 사용하여 드래그 앤 드롭 정렬 구현

Vue Sortable은 Vue.js의 구성 요소로, 고도로 사용자 정의 가능한 목록 드래그 앤 드롭 정렬 기능을 쉽게 구현할 수 있습니다. Vue Sortable에는 구성이 필요하지 않습니다. 드래그 앤 드롭 정렬 목록을 구현하려면 간단한 Vue.js 템플릿 구문만 ​​사용하면 됩니다.

Vue Sortable 설치는 npm 명령을 사용하여 수행할 수도 있습니다:

npm install vue-sortable --save
로그인 후 복사

그런 다음 아래와 같이 구성 요소에서 Vue Sortable 구성 요소를 사용합니다.

<template>
  <div>
    <ul v-sortable="{data: list, onUpdate: onUpdate}">
      <li v-for="item in list" :key="item.id">
        {{ item.id }}. {{ item.text }}
      </li>
    </ul>
  </div>
</template>

<script>
  import VueSortable from 'vue-sortable'

  export default {
    components: { VueSortable },
    data() {
      return {
        list: [
          { id: 1, text: 'Vue.js' },
          { id: 2, text: 'React.js' },
          { id: 3, text: 'Angular.js' },
          { id: 4, text: 'Ember.js' },
          { id: 5, text: 'Backbone.js' },
          { id: 6, text: 'Knockout.js' }
        ]
      }
    },
    methods: {
      onUpdate: function (event) {
        // 拖动后的排序操作
      }
    }
  }
</script>
로그인 후 복사

위 코드에서는 vue-sortable 지시어를 사용하여 목록을 설정했습니다. 정렬이 가능하도록 하고 onUpdate 콜백 함수를 사용하여 드래그 정렬이 완료된 후 목록을 업데이트합니다.

위의 세 가지 방법을 통해 Vue에서 목록 정렬 및 드래그 정렬 기능을 쉽게 구현할 수 있어 애플리케이션을 더욱 대화형으로 만들고 사용하기 쉽게 만들 수 있습니다.

위 내용은 Vue에서 목록 정렬 및 드래그 정렬을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿