Vue. js динамически изменяет выходной переход после воспроизведения ввода - PullRequest
1 голос
/ 13 февраля 2020

У меня есть динамический c переход, который говорит моему элементу двигаться влево или вправо (это элемент слайдера). Так как по умолчанию Vue позволяет мне выполнять только один переход, я использую динамическое c свойство перехода:

<transition v-bind:name="'slider-' + slideDirection">

Теперь у этого ползунка есть переходы входа и выхода, которые настраиваются в соответствии с в направлении, в котором он появляется или уходит. Все вроде бы хорошо, но ..

Когда элемент заполняет условие появления, переходы ввода и ввода выполняются правильно, всегда. Но переходы оставления и оставления не получают обновленного направления, если оно изменилось после появления элемента.

Вот скрипка, показывающая, что я имею в виду:

https://jsfiddle.net/nxLmdk9q/4/

В этом примере все работает, кроме того, как только вы меняете направление, элемент получает анимацию предыдущего направления для разрешения на отпуск.

Как это исправить?

1 Ответ

0 голосов
/ 13 февраля 2020

Похоже, что ваш слайд переход начинается до обновления slideDirection. Попробуйте использовать функцию nextTick, чтобы слайд-переход дождался обновления направления.

Обновленный пример.

new Vue({
  el: "#app",
  data: {
    slideDirection: "right",
    counter: 0
  },
  methods: {
    moveRight: function() {
      this.slideDirection = "right";
      this.$nextTick(() => {
        this.counter++;
      })

    },
    moveLeft: function() {
      this.slideDirection = "left";
      this.$nextTick(() => {
        this.counter--;
      })
    },
  }
})
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
  display: flex;
  flex-direction: column;
  width: 300px;
  height: 150px;
}

div#slider {
  position: relative;
}

div#slider div:nth-child(even) {
  background: green;
}

div#slider div:nth-child(odd) {
  background: red;
}

div {
  padding: 30px;
  width: 100%;
  height: 100%;
  position: absolute;
}

div:odd {
  background: blue;
}

.slider-right-enter {
  opacity: 0;
  transform: translatex(100%);
}

.slider-right-enter-to {
  opacity: 1;
  transition: all 0.5s ease-out;
}

.slider-right-leave-to {
  opacity: 0;
  transform: translatex(-100%);
  transition: all 0.5s ease-out;
}

.slider-left-enter {
  opacity: 0;
  transform: translatex(-100%);
}

.slider-left-enter-to {
  opacity: 1;
  transition: all 0.5s ease-out;
}

.slider-left-leave-to {
  opacity: 0;
  transform: translatex(100%);
  transition: all 0.5s ease-out;
}
<div id="app">

  <div id="slider">
    <transition v-bind:name="'slider-' + slideDirection">
      <div v-if='counter == 0'>
        0
      </div>
    </transition>

    <transition v-bind:name="'slider-' + slideDirection">
      <div v-if='counter == 1'>
        1
      </div>
    </transition>

    <transition v-bind:name="'slider-' + slideDirection">
      <div v-if='counter == 2'>
        2
      </div>
    </transition>

    <transition v-bind:name="'slider-' + slideDirection">
      <div v-if='counter == 3'>
        3
      </div>
    </transition>

  </div>

  <div>

    <button @click="moveLeft">
          &#x3C;&#x3C;
        </button>
    <button @click="moveRight"> 
          &#x3E;&#x3E;
        </button>
  </div>
</div>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...