滑动器懒惰负载不起作用(故障排除)

时间:2019-12-17 12:22:22

标签: angular web-applications lazy-loading swiper

希望您可以帮助我进行故障排除。我有一个使用swiper的Angular 8应用程序。我尝试实现延迟加载配置,以便将图像延迟加载到swiper项中,但是它加载了所有图像,并且就像我对延迟加载没有配置任何事情一样。

请参见https://swiperjs.com/api/#lazy

我在 typescript 中的swiper配置是这样的:

this.mySwiper = new Swiper('.swiper-container' {
      //some configuration. Here it comes the important part
      //...
      watchSlidesVisibility : true,
      preloadImages: false,
      lazy: true,
      breakpoints: {// Responsive
            blablabla, more than 1 per view.
      }
}

现在, html ,在此我要指出,我为每个项目使用了一个组件,所以也许是它使它无法工作的原因:

<div class="swiper-container" [ngClass]="sliderConfig.name">
    <div class="swiper-wrapper" *ngIf="!sourceImages"><!--A comprobation that really doesn't matter here-->
        <div *ngFor="let model of models" class="swiper-slide">
            <app-item [model]="model"></app-item>
        </div>
    </div>
    <!-- Add Pagination -->
    <div class="swiper-pagination"></div>
    <!-- Add Arrows -->
    <div class="swiper-button-next"><img src="../../../../../assets/images/gallery/swiper-button.svg" alt="Next"></div>
    <div class="swiper-button-prev"><img src="../../../../../assets/images/gallery/swiper-button.svg" alt="Prev"></div>
</div>

最后,项目本身:

<div class="swiper-slide" (click)="viewproject()">
    <div class="wrapper">
        <img *ngIf="model" data-src="{{link}}" class="swiper-lazy"/>
        <div class="swiper-lazy-preloader"></div>
    </div>
</div>

它的行为就像我什么都没做,我的意思是,它无论是否应该将图像加载到每个项目中,并且我尝试了删除缓存,但它仍然(不)以相同的方式工作。

2 个答案:

答案 0 :(得分:2)

hi swiper未检测到更改属性data-src = {{link}}或[data-src] =“ link”

因此请使用 [attr.data-src] =“ link” 对我有用:)

    <div class="swiper-slide" >
        <div class="wrapper">
            <img *ngIf="model" [attr.data-src]="link" class="swiper-lazy"/>
            <div class="swiper-lazy-preloader"></div>
        </div>
    </div>

答案 1 :(得分:0)

代替:

data-src="{{link}}"

您必须使用:

attr.data-src="{{link}}"

因为这是Angular期望的正确语法。 More info.