![PyPI Now Supports iOS and Android Wheels for Mobile Python Development](https://cdn.sanity.io/images/cgdhsj6q/production/96416c872705517a6a65ad9646ce3e7caef623a0-1024x1024.webp?w=400&fit=max&auto=format)
Security News
PyPI Now Supports iOS and Android Wheels for Mobile Python Development
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
angular2-useful-swiper
Advanced tools
Use iDangero.us's great slider [Swiper](http://idangero.us/swiper/#.V9C3w4VOLaI) in Angular.
Use iDangero.us's great slider Swiper in Angular.
npm install --save angular2-useful-swiper@next swiper
npm install --save-dev @types/swiper
Add the swiper styles to the app styles in angular.json.
{
"$schema": "./node_modules/@angular/cli/lib/config/schema.json",
"version": 1,
"newProjectRoot": "projects",
"projects": {
"demo": {
...
"architect": {
"build": {
"builder": "@angular-devkit/build-angular:browser",
"options": {
...
"styles": [
"./node_modules/swiper/dist/css/swiper.css"
],
...
In app.module.ts (or in whichever child module you are using the component) import the Angular2UsefulSwiperModule module.
@NgModule({
declarations: [AppComponent],
imports: [BrowserModule, Angular2UsefulSwiperModule],
providers: [],
bootstrap: [AppComponent]
})
export class AppModule {}
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.
<my-component>
<swiper [config]="config">
<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 class="swiper-slide">Slide 4</div>
<div class="swiper-slide">Slide 5</div>
<div class="swiper-slide">Slide 6</div>
<div class="swiper-slide">Slide 7</div>
<div class="swiper-slide">Slide 8</div>
<div class="swiper-slide">Slide 9</div>
<div class="swiper-slide">Slide 10</div>
</div>
<!-- Add Pagination -->
<div class="swiper-pagination"></div>
<!-- Add Arrows -->
<div class="swiper-button-next"></div>
<div class="swiper-button-prev"></div>
</swiper>
</my-component>
Set the config for the swiper in you component and bind it to the component config property as above.
export class MyComponent 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.
swiper {
height: 300px;
width: 400px;
}
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.
<swiper [config]="config">
<div class="swiper-wrapper">
<img class="swiper-slide" *ngFor="let image of images" [src]="image" />
</div>
<div class="swiper-pagination"></div>
<div class="swiper-button-next"></div>
<div class="swiper-button-prev"></div>
</swiper>
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.
.swiper-wrapper {
box-sizing: border-box;
}
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.
<mat-tabs mat-ripple mat-tab-active-index="0">
<mat-tab-panel mat-tab-panel-title="Tab1"> </mat-tab-panel>
<mat-tab-panel mat-tab-panel-title="Tab2" #panel>
<swiper [config]="config" class="wrap1" [initialize]="panel.isActive">
<div class="swiper-wrapper wrap1">
<img
class="swiper-slide"
*ngFor="let image of trigger.images"
[src]="image"
/>
</div>
<div class="swiper-pagination"></div>
<div class="swiper-button-next"></div>
<div class="swiper-button-prev"></div>
</swiper>
</mat-tab-panel>
</mat-tabs>
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
<swiper [config]="config" #usefulSwiper>
<div class="swiper-wrapper">
<img class="swiper-slide" *ngFor="let image of images" [src]="image" />
</div>
<div class="swiper-pagination"></div>
<div class="swiper-button-next"></div>
<div class="swiper-button-prev"></div>
</swiper>
..and then you can use the reference to access the swiper property.
<button (click)="usefulSwiper.swiper.createLoop()">loop</button>
To access the swiper instance and all of it's properties, methods and events use a viewchild to get the component.swiper property.
@ViewChild('usefulSwiper',{static: false S}) usefulSwiper: SwiperComponent;
...
next() {
this.usefulSwiper.swiper.slideNext();
}
FAQs
Use iDangero.us's great slider [Swiper](http://idangero.us/swiper/#.V9C3w4VOLaI) in Angular.
The npm package angular2-useful-swiper receives a total of 286 weekly downloads. As such, angular2-useful-swiper popularity was classified as not popular.
We found that angular2-useful-swiper demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
PyPI now supports iOS and Android wheels, making it easier for Python developers to distribute mobile packages.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.