朱桂飞
2023-04-03 458962a2e4a4f6af0caa5fcb3867f2e42125fd40
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
export default function updateSlidesClasses() {
    const swiper = this;
    const {
        slides,
        params,
        $wrapperEl,
        activeIndex,
        realIndex
    } = swiper;
    if (!slides.length || !$wrapperEl) return;
    const isVirtual = swiper.virtual && params.virtual.enabled;
    for (var i = 0; i < slides.length; i++) {
        slides[i].removeClass(
            `${params.slideActiveClass} ${params.slideNextClass} ${params.slidePrevClass} ${params.slideDuplicateActiveClass} ${params.slideDuplicateNextClass} ${params.slideDuplicatePrevClass}`
        );
    }
 
    let activeSlide;
 
    if (isVirtual) {
        // activeSlide = swiper.$wrapperEl.find(`.${params.slideClass}[data-swiper-slide-index="${activeIndex}"]`);
        activeSlide = slides[slides.findIndex((item) => {
            return item.dataSwiperSlideIndex == activeIndex
        })];
    } else {
        activeSlide = slides[activeIndex];
    } // Active classes
 
    if (!activeSlide) return
    activeSlide.addClass(params.slideActiveClass);
 
    if (params.loop) {
        if (activeSlide.hasClass(params.slideDuplicateClass)) {
            // $wrapperEl.children[realIndex].addClass(params.slideDuplicateActiveClass);
            let index = slides.findIndex((item) => {
                return !item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == realIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicateActiveClass);
        } else {
            // $wrapperEl.children[realIndex].addClass(params.slideDuplicateActiveClass);
            let index = slides.findIndex((item) => {
                return item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == realIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicateActiveClass);
        }
    } // Next Slide
 
 
    let nextSlide = activeSlide.nextAll(`.${params.slideClass}`)[0];
    if (nextSlide) {
        nextSlide.addClass(params.slideNextClass);
    } else {
        if (params.loop && !nextSlide) {
            nextSlide = slides[0];
            nextSlide.addClass(params.slideNextClass);
        } // Prev Slide
    }
 
 
 
    let prevSlide = activeSlide.prevAll(`.${params.slideClass}`)[0];
    if (prevSlide) {
        prevSlide.addClass(params.slidePrevClass);
    } else {
        if (params.loop && !prevSlide) {
            prevSlide = slides[slides.length - 1];
            prevSlide.addClass(params.slidePrevClass);
        }
    }
 
 
    if (params.loop) {
        // Duplicate to all looped slides
        if (nextSlide.hasClass(params.slideDuplicateClass)) {
            // $wrapperEl.children(
            //     nextSlide.dataSwiperSlideIndex
            // ).addClass(params.slideDuplicateNextClass);
 
            let index = slides.findIndex((item) => {
                return !item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == nextSlide
                    .dataSwiperSlideIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicateNextClass);
 
 
        } else {
            // $wrapperEl.children(
            //     nextSlide.dataSwiperSlideIndex
            // ).addClass(params.slideDuplicateNextClass);
 
            let index = slides.findIndex((item) => {
                return item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == nextSlide
                    .dataSwiperSlideIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicateNextClass);
        }
        if (prevSlide.hasClass(params.slideDuplicateClass)) {
            // $wrapperEl.children(
            //     prevSlide.dataSwiperSlideIndex
            // ).addClass(params.slideDuplicatePrevClass);
            let index = slides.findIndex((item) => {
                return !item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == prevSlide
                    .dataSwiperSlideIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicatePrevClass);
        } else {
            // $wrapperEl.children(
            //     prevSlide.dataSwiperSlideIndex
            // ).addClass(params.slideDuplicatePrevClass);
            let index = slides.findIndex((item) => {
                return item.hasClass(params.slideDuplicateClass) && item.dataSwiperSlideIndex == prevSlide
                    .dataSwiperSlideIndex
            })
            slides[index] && slides[index].addClass(params.slideDuplicatePrevClass);
        }
    }
 
    swiper.emitSlidesClasses();
}