如果您追求延迟加载方法,您可以执行以下操作:
- 添加一个 div 包装器并将其背景设为灰色(例如骨架 UI)或将其指向 URL(我使用外部但您可以使用本地资产中的 img)
- 如果它是活动幻灯片或从中 +1 索引,则使用属性绑定条件仅设置实际 img 的 src(您可以在此处更改您需要的条件)
- 在加载实际图像时 - 在数据模型中设置一个标志以保持 src 完整,如果图像已经加载
html模板:
<ion-content>
<div>
<ion-slides #sliders pager="true" spaceBetween="5">
<ion-slide *ngFor='let imgItem of images; index as i;'>
<div class="lazySlide">
<img class="lazyImage" [src]="(sliders.getActiveIndex() == i || sliders.getActiveIndex() == i-1) || imgItem.loaded? imgItem.source:''" (load)="imgItem.loaded=true">
</div>
</ion-slide>
</ion-slides>
</div>
</ion-content>
组件代码示例:
import { Component } from '@angular/core';
@Component({
selector: 'page-home',
templateUrl: 'home.html'
})
export class HomePage {
images: Array<{ loaded: boolean, source: string}> = [
{
loaded: false,
source: "https://placeimg.com/1000/1000/nature"
},
{
loaded: false,
source: "https://placeimg.com/1000/1000/people"
},
{
loaded: false,
source: "https://placeimg.com/1000/1000/tech"
},
{
loaded: false,
source: "https://placeimg.com/1000/1000/architecture"
},
{
loaded: false,
source: "https://placeimg.com/1000/1000/animals"
}
]
constructor(
) {
}
}
scss:
page-home {
.lazyImage {
width: 100%;
height: 100%;
}
.lazySlide {
background: url(http://via.placeholder.com/1000x1000);
}
}