Vue. js Переходы - вход и выход, в зависимости от значения приращения / убывания - PullRequest
1 голос
/ 06 января 2020

В настоящее время у меня есть следующий компонент блока перехода:

<div
   v-if="!surveyResultIsReady"
   class="vh-md-40 position-relative"
   >
   <transition
      name="custom-classes-transition"
      enter-active-class="animated slideInRight"
      leave-active-class="animated slideOutLeft"
      >
      <div
         v-bind:key="step"
         class="w-100 position-absolute mx-auto"
         >
         <SurveyActiveQuestion
            v-if="!surveyResultIsReady"
            v-bind:question="activeQuestion()"
            v-bind:totalQuestions="totalQuestions"
            v-on:activeQuestionAnswered="activeQuestionAnswered()"
            />
      </div>
   </transition>
</div>

Переход регулируется значением this.step (v-bind:key="step").

Переход выглядит великолепно, когда this.step++ переход смахивает в «правильном» направлении: смахивает слева направо. Однако, когда this.step-- переход такой же.

Мне было интересно, как бы я исправил это, чтобы провести пальцем справа налево в направлении this.step--?

Ответы [ 2 ]

1 голос
/ 06 января 2020

Вам нужно два разных CSS ввода состояний для перехода, потому что вы хотите скользить в обоих направлениях. Используя привязку для enter-class (не то же самое, что enter-active-class), вы можете изолировать расположение слайдов в 2 отдельных CSS ввода классов и поменять их местами на основе изменения в step. Например, вот новая привязка:

:enter-class="enterClass"

enterClass - это свойство данных, для которого задана строка имени увеличивающегося или уменьшающегося имени класса с использованием watch в step:

watch: {
  step(old, value) {
    this.enterClass = value > old ? 'slide-in-right' : 'slide-in-left'; 
  }
}

А вот классы:

.animated {
  transition: transform .5s;
}
.slide-in-left {
  transform: translate(-100%, 0);
}
.slide-in-right {
  transform: translate(100%, 0);
}

DEMO Собрав все воедино, вот упрощенная версия вашего кода:

new Vue({
  el: "#app",
  data() {
    return {
      step: 1,
      enterClass: ''
    }
  },
  watch: {
    step(value, old) {
      this.enterClass = value > old ? 'slide-in-left' : 'slide-in-right'; 
    }
  }
});
[v-cloak] {
  display:none;
}

#app {
  background: #fff;
  border-radius: 4px;
}

.slider {
  position: relative;
  overflow-x: hidden;
  border: 1px solid #cccccc;
  border-radius: 3px;
  height: 40px;
  margin-bottom: 4px;
}

.slider > div {
  position: absolute;
  width: 100%;
  text-align: center;
}

.animated {
  transition: transform .5s;
}
.slide-in-left {
  transform: translate(-100%, 0);
}
.slide-in-right {
  transform: translate(100%, 0);
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script>
<div id="app" v-cloak>
  <div class="slider">
    <transition name="slide"
      enter-active-class="animated"
      :enter-class="enterClass"
    >
      <div :key="step">
        Content <br />
        {{ step }}
      </div>
    </transition>
  </div>
  <button @click="--step">-</button>
  <button @click="++step">+</button>
</div>

Вы можете добавить leave-class таким же образом, если хотите сделать его более интересным

0 голосов
/ 07 января 2020

Вы можете использовать GSAP. Я видел это в видео (ссылка с временем) https://youtu.be/14yOawLavB0?t=734 есть пример кода (вы можете легко использовать его со своими шагами) и результат.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...