source

Vuejs 목록 순서 변경이 전환을 트리거하지 않음

gigabyte 2022. 8. 16. 23:29
반응형

Vuejs 목록 순서 변경이 전환을 트리거하지 않음

저는 거의 1년 동안 vuej를 몇 개 했지만 애니메이션과 트랜지션이 제대로 작동하지 않았습니다.이 모든 것이 어떻게 동작해야 하는지 매우 불명확한 것 같습니다.오늘은 그것들을 이해하려고 했습니다만, 다시 한 번 말씀드리지만, 트랜지션이 제대로 작동하지 않고, 무엇을 잘못하고 있는지 이해할 수 없습니다.코드는 다음과 같습니다.

HTML

<div id="app">
 <div class="row">
      <div class="container-fluid">
        <transition-group name="flip-list" tag="div" class="row horizontal-scroll">
          <div class="col-xs-12 col-md-2 col-lg-2 col-card" 
            v-for="(someCard, index) in someCards" v-bind:key="index">
            <div class="some-card" @click="changeOrder(someCard)">
              {{ someCard.someTitle }}
            </div>
          </div>
        </transition-group>
      </div>
    </div>
</div>

JS

new Vue({
  el: "#app",
  data: {
    someCards: [
          {
            order: 2,
            someTitle: 'Title 1'
          },
          {
            order: 2,
            someTitle: 'Title 2'
          },
          {
            order: 2,
            someTitle: 'Title 3'
          },
          {
            order: 3,
            someTitle: 'Title 4'
          },
          {
            order: 3,
            someTitle: 'Title 5'
          },
          {
            order: 1,
            someTitle: 'Title 6'
          },
          {
            order: 1,
            someTitle: 'Title 7'
          },
          {
            order: 1,
            someTitle: 'Title 8'
          },
          {
            order: 3,
            someTitle: 'Title 1'
          }
        ]
  },
  methods: {
    changeOrder(someCardData) {
        let newRandom = Math.floor(Math.random() * 3) + 1;
        while (newRandom === someCardData.order) {
          newRandom = Math.floor(Math.random() * 3) + 1;
        }
        someCardData.order = newRandom;
        this.reorderList();
      },
      reorderList() {
        this.someCards.sort(function(objA, objB) {
          return objA.order - objB.order;
        })
      },
  }
})

CSS

/* default */
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}
#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}
/* bootstrap */
.row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}
.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-auto, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-sm-auto, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-md-auto, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-lg-auto, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl, .col-xl-auto {
    position: relative;
    width: 100%;
    min-height: 1px;
    padding-right: 15px;
    padding-left: 15px;
}

/* my css */
.horizontal-scroll {
  overflow-x: auto;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
}
.col-card {
  max-width: 14%;
}
.some-card {
  height: 220px;
  font-size: 16px;
  text-align: center;
  padding-right: 5px;
  margin-top: 5px;
  -webkit-box-shadow: 1px 1px 5px rgba(0,0,0,.1);
  box-shadow: 1px 1px 5px rgba(0,0,0,.1);
  border-radius: 2px;
  background: #fff;
  margin-bottom: 20px;
  position: relative;
  border-top-style: solid;
}
.flip-list-move {
  transition: transform 1s;
}

https://jsfiddle.net/eywraw8t/459088/

일렬로 정렬된 카드 목록에서 카드를 다시 주문할 때 애니메이션을 트리거하려고 합니다.카드의 위치를 변경하려면 클릭하기만 하면 됩니다.재주문은 가능하지만 전환은 이루어지지 않습니다.

이 매뉴얼 https://vuejs.org/v2/guide/transitions.html#List-Move-Transitions을 사용하여 매우 간단한 튜토리얼을 몇 개 봤는데 뭔가 부족한 게 있을 것 같습니다.누가 코드를 확인해서 뭔지 말해줄래요?

고마워요.

색인을 열쇠로 사용하고 있기 때문입니다.카드가 변경되어도 인덱스는 같은 위치에 대해 항상 동일합니다.카드마다 고유 ID를 부여하고 대신 그것을 키로 사용합니다.

new Vue({
  el: "#app",
  data: {
    someCards: [{
        id: 0,
        order: 2,
        someTitle: 'Title 1'
      },
      {
        id: 1,
        order: 2,
        someTitle: 'Title 2'
      },
      {
        id: 2,
        order: 2,
        someTitle: 'Title 3'
      },
      {
        id: 3,
        order: 3,
        someTitle: 'Title 4'
      },
      {
        id: 4,
        order: 3,
        someTitle: 'Title 5'
      },
      {
        id: 5,
        order: 1,
        someTitle: 'Title 6'
      },
      {
        id: 6,
        order: 1,
        someTitle: 'Title 7'
      },
      {
        id: 7,
        order: 1,
        someTitle: 'Title 8'
      },
      {
        id: 8,
        order: 3,
        someTitle: 'Title 1'
      }
    ]
  },
  methods: {
    changeOrder(someCardData) {
      let newRandom = Math.floor(Math.random() * 3) + 1;
      while (newRandom === someCardData.order) {
        newRandom = Math.floor(Math.random() * 3) + 1;
      }
      someCardData.order = newRandom;
      this.reorderList();
    },
    reorderList() {
      this.someCards.sort(function(objA, objB) {
        return objA.order - objB.order;
      })
    },
  }
})
/* default */

body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}


/* bootstrap */

.row {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}

.col-1,
.col-2,
.col-3,
.col-4,
.col-5,
.col-6,
.col-7,
.col-8,
.col-9,
.col-10,
.col-11,
.col-12,
.col,
.col-auto,
.col-sm-1,
.col-sm-2,
.col-sm-3,
.col-sm-4,
.col-sm-5,
.col-sm-6,
.col-sm-7,
.col-sm-8,
.col-sm-9,
.col-sm-10,
.col-sm-11,
.col-sm-12,
.col-sm,
.col-sm-auto,
.col-md-1,
.col-md-2,
.col-md-3,
.col-md-4,
.col-md-5,
.col-md-6,
.col-md-7,
.col-md-8,
.col-md-9,
.col-md-10,
.col-md-11,
.col-md-12,
.col-md,
.col-md-auto,
.col-lg-1,
.col-lg-2,
.col-lg-3,
.col-lg-4,
.col-lg-5,
.col-lg-6,
.col-lg-7,
.col-lg-8,
.col-lg-9,
.col-lg-10,
.col-lg-11,
.col-lg-12,
.col-lg,
.col-lg-auto,
.col-xl-1,
.col-xl-2,
.col-xl-3,
.col-xl-4,
.col-xl-5,
.col-xl-6,
.col-xl-7,
.col-xl-8,
.col-xl-9,
.col-xl-10,
.col-xl-11,
.col-xl-12,
.col-xl,
.col-xl-auto {
  position: relative;
  width: 100%;
  min-height: 1px;
  padding-right: 15px;
  padding-left: 15px;
}


/* my css */

.horizontal-scroll {
  overflow-x: auto;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
}

.col-card {
  max-width: 14%;
}

.some-card {
  height: 220px;
  font-size: 16px;
  text-align: center;
  padding-right: 5px;
  margin-top: 5px;
  -webkit-box-shadow: 1px 1px 5px rgba(0, 0, 0, .1);
  box-shadow: 1px 1px 5px rgba(0, 0, 0, .1);
  border-radius: 2px;
  background: #fff;
  margin-bottom: 20px;
  position: relative;
  border-top-style: solid;
}

.flip-list-move {
  transition: transform 1s;
}
<script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>

<div id="app">
  <div class="row">
    <div class="container-fluid">
      <transition-group name="flip-list" tag="div" class="row horizontal-scroll">
        <div class="col-xs-12 col-md-2 col-lg-2 col-card" v-for="(someCard, index) in someCards" v-bind:key="someCard.id">
          <div class="some-card" @click="changeOrder(someCard)">
            {{ someCard.someTitle }}
          </div>
        </div>
      </transition-group>
    </div>
  </div>
</div>

JSFiddle

언급URL : https://stackoverflow.com/questions/53299573/vuejs-list-reorder-doesnt-trigger-transitions

반응형