ngx-useful-swiper
Use iDangero.us's great slider Swiper in Angular.
Quick links
Install
npm install --save ngx-useful-swiper@latest swipernpm install --save-dev @types/swiper
Add the swiper styles to the app styles in angular.json.
Usage
In app.module.ts (or in whichever child module you are using the component) import the NgxUsefulSwiperModule module.
Add the swiper component to your component to create a slider and add the content as you normally would to set up a slider (see the official demos for more information). Note, you don't need to include the swiper-container div just the content, but the slides should be contained in a swiper-wrapper div and have the class swiper-slide.
Slide 1 Slide 2 Slide 3 Slide 4 Slide 5 Slide 6 Slide 7 Slide 8 Slide 9 Slide 10 <!-- Add Pagination --> <!-- Add Arrows -->
Set the config for the swiper in you component and bind it to the component config property as above.
implements OnInit config: SwiperOptions = pagination: el: '.swiper-pagination' clickable: true navigation: nextEl: '.swiper-button-next' prevEl: '.swiper-button-prev' spaceBetween: 30 ;
Set the height and width of the component.
The component also checks for the contents of swiper-wrapper being changed and calls update on the swiper when they are. This allows for dynamic slide lists as you can see from the demo in this repo.
note for Bootstrap users
To ensure the swiper works will with a column layout you may need to set the box-sizing to border-box on the swiper-wrapper.
Manually initializing the Swiper
By default the Swiper will be created in the AfterViewChecked event of the component. If the swiper is not going to have been rendered at this time (if it is on a hidden tab for example), it is best to handle the initialization manually. To do this use the component's initialize property and only set it's value to true when ready. This will then initialize the Swiper the next time the next AfterViewChecked event is fired to ensure the DOM is ready.
Accessing the Swiper instance
When a new instance of Swiper is created it is set as a property on the component. You can then access this by using a template reference. For example add the template reference #usefulSwiper
..and then you can use the reference to access the swiper property.
loop
To access the swiper instance and all of it's properties, methods and events use a viewchild to get the component.swiper property.
usefulSwiper: SwiperComponent; ... next