Javascript 如何在同一页面上使用多个ngx滑动转盘?
我在我的页面上使用了slick转盘,但它给了我一个错误,并且没有显示第二个转盘。 slider.component.tsJavascript 如何在同一页面上使用多个ngx滑动转盘?,javascript,jquery,angular,carousel,slick.js,Javascript,Jquery,Angular,Carousel,Slick.js,我在我的页面上使用了slick转盘,但它给了我一个错误,并且没有显示第二个转盘。 slider.component.ts <div *ngIf="mainSlider"> <div class="main__slider"> <ngx-slick-carousel class="carousel" #slickModal="slick-carousel" [con
<div *ngIf="mainSlider">
<div class="main__slider">
<ngx-slick-carousel class="carousel" #slickModal="slick-carousel" [config]="slideConfig">
<div ngxSlickItem *ngFor="let slide of slides" class="slide">
<div class="main__slide">
<div class="main__slide-inner">
<img class="main__slide-image" src="/assets/img/{{slide.img}}.svg" alt="">
<div class="main__slide-title">
Lorem ipsum dolor sit amet.
</div>
<div class="main__slide-subtitle">
Lorem ipsum dolor sit, amet consectetur adipisicing elit. Nulla, odit?
</div>
<div class="main__slide-button">
<div class="main__slide-hint">
<img src="assets/img/sandglass.svg" alt="">Lorem ipsum dolor sit amet, consectetur
adipisicing elit. Deleniti esse atque eveniet incidunt.
</div>
<img src="assets/img/icons/dotted-arrow.svg" alt="">
<a class="button-blue" href="#">
Lorem ipsum dolor sit.
</a>
</div>
</div>
</div>
</div>
</ngx-slick-carousel>
</div>
<div class="main__slider-arrows">
<button class="slick-arrow" (click)="prev()"><img src="assets/img/icons/arrow-slider.svg" alt=""></button>
<button class="slick-arrow" style="transform: rotateY(180deg);" (click)="next()"><img
src="assets/img/icons/arrow-slider.svg" alt=""></button>
</div>
<div class="main__slider-info">
<div class="slider-index">
<span class="current-slide">01</span>/<span class="num-slide">03</span>
</div>
<div class="slider-progress">
<div class="slider-progress__back"></div>
<span [style.width.%]="progressBarWidth"></span>
</div>
</div>
</div>
<div *ngIf="eventsSlider">
<div class="news-slider-mobile">
<ngx-slick-carousel class="carousel" #eventsModal="slick-carousel" [config]="slideConfig">
<div class="events-slider">
<div class="events-slider__arrows news-arrows active-arrows"></div>
<div class="events-slider__arrows activity-arrows"></div>
<div class="events__tabs">
<div class="title tab news-tab active">
News
</div>
<div class="switch first-on">
<span></span>
</div>
<div class="title tab activity-tab">
Events
</div>
</div>
<div class="events__tab-content">
<div class="news-item tab-item active-tab">
<div class="news-slider-mobile">
<a *ngFor="let banner of eventsBanners" href="#" class="events__item">
<div class="events__item-image">
<img src="assets/img/{{ banner.img }}.png" alt="">
</div>
<div class="events__item-wrapper">
<div class="date-view">
<div class="date-view__date">
<img src="images/icons/calendar.svg" alt="">${{banner.date}}
</div>
<div class="date-view__view">
<img src="images/icons/eye.svg" alt="">${{banner.views}}
</div>
</div>
</div>
<div class="events__item-title">
${{banner.title}}
</div>
<div class="events__item-text">
${{banner.description}}
</div>
</a>
</div>
</div>
</div>
</div>
</ngx-slick-carousel>
</div>
</div>
import { Component, OnInit, ViewChild, Input } from '@angular/core';
import { SlickCarouselComponent } from 'ngx-slick-carousel';
import { eventsBanners } from './banners';
@Component({
selector: 'app-slider',
templateUrl: './slider.component.html',
styleUrls: ['./slider.component.scss']
})
export class SliderComponent implements OnInit {
@Input() mainSlider: boolean;
@Input() eventsSlider: boolean;
@ViewChild('slickModal') slickModal: SlickCarouselComponent;
@ViewChild('eventsModal') eventsModal: SlickCarouselComponent;
...
next() {
console.log(this.slickModal) // gives first modal
console.log(this.eventsModal) // gives undefined
this.slickModal.slickNext();
}
我在主页上导入应用程序滑块主页面.component.html
<section class="main">
<div class="container">
<div class="main__inner">
<app-slider mainSlider="true"></app-slider>
</div>
</div>
</section>
<section class="events">
<div class="container">
<app-slider eventsSlider="true"></app-slider>
</div>
</section>
这里有一个错误
TypeError:无法读取未定义的属性“slickNext”
有人能帮我修一下吗?我应该如何在同一页/文件上使用2
?问题是我的第二个滑块的html不正确,两个滑块可以工作。据我所知,在ngx滑头转盘之后,孩子应该有ngxSlickItem
<div *ngIf="eventsSlider">
<div class="events-slider">
<div class="events-slider__arrows news-arrows active-arrows"></div>
<div class="events-slider__arrows activity-arrows"></div>
<div class="events__tabs">
<div class="title tab news-tab active">
news
</div>
<div class="switch first-on">
<span></span>
</div>
<div class="title tab activity-tab">
events
</div>
</div>
<div class="events__tab-content">
<div class="news-item tab-item active-tab">
<div class="news-slider">
<ngx-slick-carousel class="carousel" #eventsModal="slick-carousel" [config]="slideConfig">
<a ngxSlickItem *ngFor="let banner of eventsBanners" href="#" class="events__item">
<div class="events__item-image">
<img src="assets/img/{{ banner.img }}.png" alt="">
</div>
<div class="events__item-wrapper">
<div class="date-view">
<div class="date-view__date">
<img src="images/icons/calendar.svg" alt="">{{banner.date}}
</div>
<div class="date-view__view">
<img src="images/icons/eye.svg" alt="">{{banner.views}}
</div>
</div>
</div>
<div class="events__item-title">
{{banner.title}}
</div>
<div class="events__item-text">
{{banner.description}}
</div>
</a>
</ngx-slick-carousel>
</div>
</div>
</div>
</div>
TypeError:无法读取未定义的属性“slickNext”
next() {
this.mainBanner.slickNext();
}
@ViewChild('slickModal') mainBanner: SlickCarouselComponent;
@ViewChild('eventsModal') eventsModal: SlickCarouselComponent;