'How to change swipe direction in swiper.js?

I'm struggling with changing swipe direction when I rotate my swiper on 90deg. So in the beginning by default it has horizontal direction. When clicking on slide I'm rotating "swiper-container" making it full screen . So it still has swiping direction from left to right , but I need to change from top to bottom without changing in params direction to vertical .

const topSwiper = new Swiper(this.DOMTopSwiper.current, {
  spaceBetween: 0,
  observer: true,
  observeParents: true,
  observeSlideChildren: true,
  direction: "vertical",
  navigation: {
    nextEl: ".top-swiper-button-next",
    prevEl: ".top-swiper-button-prev",
  },
  pagination: {
    el: ".zoom-amount-slides",
    type: "fraction",
  },
})


Solution 1:[1]

Destroy previous Swiper and reinitialize Swiper giving the direction value. Here is doc

DEMO

let isVertical = true,
  direction = 'vertical';
let swiper = initSwiper(direction);

function initSwiper(direction) {
  return new Swiper('.swiper-container', {
    spaceBetween: 50,
    pagination: {
      el: '.swiper-pagination',
      clickable: true,
    },
    direction: direction
  });

}

function changeDirection() {
  isVertical = !isVertical;
  direction = isVertical ? 'vertical' : 'horizontal';
  let slideIndex = swiper.activeIndex;
  swiper.destroy(true, true);
  swiper = initSwiper(direction);
  swiper.slideTo(slideIndex,0);
}
html, body {
  position: relative;
  height: 100%;
}
body {
  background: #eee;
  font-family: Helvetica Neue, Helvetica, Arial, sans-serif;
  font-size: 14px;
  color:#000;
  margin: 0;
  padding: 0;
}
.swiper-container {
  width: 400px;
  height: 400px;
}
.swiper-slide {
  text-align: center;
  font-size: 18px;
  background: #fff;
  /* Center slide text vertically */
  display: -webkit-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}
<!-- Link Swiper's CSS -->
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Swiper/4.4.6/css/swiper.min.css">
<!-- Swiper JS -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/Swiper/4.4.6/js/swiper.js"></script>
<button onclick='changeDirection()'>Change Direction</button>
<!-- Swiper -->
<div class="swiper-container">
  <div class="swiper-wrapper">
    <div class="swiper-slide">Slide 1</div>
    <div class="swiper-slide">Slide 2</div>
    <div class="swiper-slide">Slide 3</div>
  </div>
  <!-- Add Pagination -->
  <div class="swiper-pagination"></div>
</div>

Solution 2:[2]

Try my solution.

//Tested in Swiper 7.2.0
/**
 * Insert to your page
 */
var rotate90Swiper = (function (swiper, optIsRotate90) {
    var isRoate90 = !!optIsRotate90
    swiper.___touches = {}
    swiper.___touches.currentX = swiper.touches.currentX
    Object.defineProperty(swiper.touches, 'currentX', {
        set: function (v) {
            if (!isRoate90) {
                swiper.___touches.currentX = v
            } else {

                swiper.___touches.currentY = v
            }

        },
        get: function () {
            return swiper.___touches.currentX
        }
    })
    swiper.___touches.currentY = swiper.touches.currentY
    Object.defineProperty(swiper.touches, 'currentY', {
        set: function (v) {
            if (!isRoate90) {
                swiper.___touches.currentY = v
            } else {
                swiper.___touches.currentX = v
            }
        },
        get: function () {
            return swiper.___touches.currentY
        }
    })
    return function (b) {
        isRoate90 = b
    }
})

/**
 * How to use
 */
var setRotate90 = rotate90Swiper(YourSwiperInstance, defaultIsRotate90)
setRotate90(false) // swiper rotate 90deg
setRotate90(true)   //normal swiper

Solution 3:[3]

For who's searching this in 2022, now is possible to update direction using swiper.changeDirection('vertical'); // or horizontal

complete example here: https://stackblitz.com/edit/swiper-demo-43-change-direction

Solution 4:[4]

Quick edit if you need to rotate at 180 your swiperjs

var rotate180Swiper = (function (swiper, optIsRotate180) {
        var isRoate180 = !!optIsRotate180
        swiper.___touches = {}
        swiper.___touches.currentX = swiper.touches.currentX
        Object.defineProperty(swiper.touches, 'currentX', {
                set: function (v) {
                        if (!isRoate180) {
                                swiper.___touches.currentX = -v
                        } else {

                                swiper.___touches.currentX = v
                        }

                },
                get: function () {
                        return swiper.___touches.currentX
                }
        })

        return function (b) {
                isRoate180 = b
        }
})

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Durga
Solution 2 lei li
Solution 3 Jinxmcg
Solution 4 Choussich0uss