Maison > Questions et réponses > le corps du texte
J'utilise les menus liés aux balises Vuejs
制作了我的项目,并使用 Swiper
来滑动与页面 sections
.
Je souhaite que le curseur Swiper
change automatiquement à mesure que l'utilisateur fait défiler ma page.
J'ai essayé le code suivant :
Swipe code
<swiper :slidesPerView="2.3" :spaceBetween="30" :centeredSlides="true" @swiper="onSwiper"> <swiper-slide v-for="(item,index) in categoriesList" :key="index"> <CategoryItem :title="item.title" :icon="item.icon"/> </swiper-slide> </swiper>
Exemple d'élément de catégorie :
categoriesList: [ { foodsCount: 2, title: 'Pizza', icon: 'pizza.svg', tag: 'abcd-efgh-ijkl-mno1', }, ];
Partie
<section :id="'category-' + item.tag" v-for="(item,index) in categoriesList" :key="index"> <div class="text-center q-mb-md"> <b class="section-title">{{ item.title }}</b> </div> <food-item class="q-mb-md" v-for="i in item.foodsCount" :key="i"/> </section>
Hook créé (vérifier le code défilant)
created() { window.onscroll = () => { let current = ""; let prevIndex = this.currentIndex; let sections = document.querySelectorAll('section') sections.forEach((section) => { const sectionTop = section.offsetTop; if (pageYOffset >= sectionTop) { current = section.getAttribute("id"); this.currentIndex = this.categoriesList.findIndex(item => item.tag === current.replace('category-', '')) } }); if (this.currentIndex !== prevIndex) { let i = 0 document.querySelectorAll('.swiper-slide').forEach(item => { if (this.currentIndex === i) { item.classList = 'swiper-slide swiper-slide-active' } else if (this.currentIndex === (i - 1)) { item.classList = 'swiper-slide swiper-slide-next' } else if (this.currentIndex === (i + 1)) { item.classList = 'swiper-slide swiper-slide-previous' } else { item.classList = 'swiper-slide'; } i++; }) } };
Remarque : je ne peux pas utiliser la fonction SlideTo
car elle casse la dynamique lors du défilement.
Je pense que cela a quelque chose à voir avec le transform
风格有关 swiper-wrapper
div mais je ne peux pas le gérer.
<div class="swiper-wrapper" style="transition-duration: 0ms; transform: translate3d(*, *, *);">
Y a-t-il une solution ?
P粉4733635272024-01-17 09:22:16
C’est ce que je fais, pas de problème.
if (this.currentIndex !== prevIndex) { let i = 0 document.querySelectorAll('.swiper-slide').forEach(item => { if (this.currentIndex === i) { item.classList = 'swiper-slide swiper-slide-active' document.querySelector('.swiper-wrapper').style.transform = "translate3d(" + this.swiperCategory.snapGrid[i] + "px, 0, 0)"; document.querySelector('.swiper-wrapper').style.transitionDuration = "300ms"; } else if (this.currentIndex === (i - 1)) { item.classList = 'swiper-slide swiper-slide-next' } else if (this.currentIndex === (i + 1)) { item.classList = 'swiper-slide swiper-slide-previous' } else { item.classList = 'swiper-slide'; } i++; }) }