Ng-lazyload-image: Ne fonctionne pas avec angulaire 5

Créé le 9 nov. 2017  ·  4Commentaires  ·  Source: tjoskar/ng-lazyload-image

Salut, j'ai essayé cette bibliothèque dans angulaire 5 mais je n'arrive pas à la faire fonctionner. J'ai un modèle de composant comme ça

<a class="card clickable" [routerLink]="[product.id]">
    <div class="card-img">
      <img [lazyLoad]="product.logoUrl">
    </div>
  <div class="card-block">
    <span class="card-media-title">{{product.name}}</span>
    <div class="product-version">{{product.version}}</div>
    <div class="product-release-date">{{product.releaseDate}}</div>
  </div>
</a>

et un composant comme ça

import {Component, Input} from '@angular/core';
import {Product} from '../products.state';

@Component({
  selector: 'app-product-card',
  templateUrl: './product-card.component.html',
  styleUrls: ['./product-card.component.scss']
})
export class ProductCardComponent {

  @Input() product: Product;

  constructor() {
  }

}

Et mon module

import {NgModule} from '@angular/core';
import {CommonModule} from '@angular/common';
import {LazyLoadImageModule} from 'ng-lazyload-image';
import {ProductsComponent} from './products.component';
import {ProductsEpic} from './products.epic';
import {ProductsListComponent} from './products-list/products-list.component';
import {ProductCardComponent} from './product-card/product-card.component';
import {ProductsService} from './products.service';
import {ProductsActions} from './products.actions';
import {ProductsEmptyComponent} from './products-empty/products-empty.component';
import {CoreModule} from '../core/core.module';
import {BannerComponent} from './banner/banner.component';
import {RouterModule} from '@angular/router';

@NgModule({
  imports: [
    CommonModule,
    RouterModule,
    CoreModule,
    LazyLoadImageModule
  ],
  declarations: [
    ProductsComponent,
    ProductsListComponent,
    ProductCardComponent,
    ProductsEmptyComponent,
    BannerComponent
  ],
  providers: [
    ProductsService,
    ProductsEpic,
    ProductsActions
  ]
})
export class ProductsModule {
}

L'image n'apparaît tout simplement jamais. Je reçois également ce message d'avertissement dans la console

image

Je ne sais pas ce que je fais mal. Toute aide appréciée

Commentaire le plus utile

Mes excuses. J'ai regardé de plus près mon problème et il s'est avéré que j'avais ce morceau de css qui semblait désactiver tous les événements de défilement dans le navigateur

html, body {
  overflow-x: hidden;
}

Pour contourner ce problème, j'ai ajouté cet événement de défilement personnalisé comme ceci

import {Component, Input} from '@angular/core';
import {Product} from '../products.state';
import {Observable} from 'rxjs/Observable';

@Component({
  selector: 'app-product-card',
  templateUrl: './product-card.component.html',
  styleUrls: ['./product-card.component.scss']
})
export class ProductCardComponent {

  @Input() product: Product;
  scrollObservable = Observable.fromEvent(document.body, 'scroll');

  constructor() {
  }

}

et dans mon modèle comme ça

<a class="card clickable" [routerLink]="[product.id]">
  <div class="card-img">
    <img [lazyLoad]="product.logoUrl" [scrollObservable]="scrollObservable">
  </div>
  <div class="card-block">
    <span class="card-media-title">{{product.name}}</span>
    <div class="product-version">{{product.version}}</div>
    <div class="product-release-date">{{product.releaseDate}}</div>
  </div>
</a>

Maintenant, cela fonctionne parfaitement en angulaire 5

Tous les 4 commentaires

Salut @el-davo,

Merci pour le rapport. Utilisez-vous un rendu de serveur ? Ou précompiler votre application ? Ou exécutez-vous l'application en mode développement ?

Salut. Non, je ne fais pas de rendu côté serveur. Oui actuellement en mode dev en utilisant le angular-cli

Quel navigateur utilisez-vous?
Je viens de créer une nouvelle application angulaire avec le cli (Angular 5) et je n'ai pas pu reproduire cela. J'ai fait les modifications suivantes :

diff --git a/src/app/app.component.html b/src/app/app.component.html
index 46d517b..215f0c9 100644
--- a/src/app/app.component.html
+++ b/src/app/app.component.html
@@ -6,15 +6,21 @@
   <img width="300" src="">
 </div>
 <h2>Here are some links to help you start: </h2>
+<img [defaultImage]="defaultImage" [lazyLoad]="image">
 <ul>
   <li>
     <h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2>
diff --git a/src/app/app.component.ts b/src/app/app.component.ts
index 7b0f672..cf8cead 100644
--- a/src/app/app.component.ts
+++ b/src/app/app.component.ts
@@ -7,4 +7,6 @@ import { Component } from '@angular/core';
 })
 export class AppComponent {
   title = 'app';
+  defaultImage = 'https://www.placecage.com/1000/1000';
+  image = 'https://images.unsplash.com/photo-1443890923422-7819ed4101c0?fm=jpg';
 }
diff --git a/src/app/app.module.ts b/src/app/app.module.ts
index 926975a..7fb6d9d 100644
--- a/src/app/app.module.ts
+++ b/src/app/app.module.ts
@@ -1,18 +1,13 @@
 import { BrowserModule } from '@angular/platform-browser';
 import { NgModule } from '@angular/core';
+import { LazyLoadImageModule } from 'ng-lazyload-image';
 import { AppComponent } from './app.component';

 @NgModule({
   declarations: [
     AppComponent
   ],
   imports: [
    BrowserModule,
+   LazyLoadImageModule
   ],
   providers: [],
   bootstrap: [AppComponent]
 })
 export class AppModule { }

J'ai également créé un plnkr (https://embed.plnkr.co/rr046QU9YYWALdX7Xzf6/) mais je n'ai pas pu reproduire l'erreur.
Pensez-vous pouvoir créer un petit dépôt git ou un plnkr pour reproduire l'erreur ?

Mes excuses. J'ai regardé de plus près mon problème et il s'est avéré que j'avais ce morceau de css qui semblait désactiver tous les événements de défilement dans le navigateur

html, body {
  overflow-x: hidden;
}

Pour contourner ce problème, j'ai ajouté cet événement de défilement personnalisé comme ceci

import {Component, Input} from '@angular/core';
import {Product} from '../products.state';
import {Observable} from 'rxjs/Observable';

@Component({
  selector: 'app-product-card',
  templateUrl: './product-card.component.html',
  styleUrls: ['./product-card.component.scss']
})
export class ProductCardComponent {

  @Input() product: Product;
  scrollObservable = Observable.fromEvent(document.body, 'scroll');

  constructor() {
  }

}

et dans mon modèle comme ça

<a class="card clickable" [routerLink]="[product.id]">
  <div class="card-img">
    <img [lazyLoad]="product.logoUrl" [scrollObservable]="scrollObservable">
  </div>
  <div class="card-block">
    <span class="card-media-title">{{product.name}}</span>
    <div class="product-version">{{product.version}}</div>
    <div class="product-release-date">{{product.releaseDate}}</div>
  </div>
</a>

Maintenant, cela fonctionne parfaitement en angulaire 5

Cette page vous a été utile?
0 / 5 - 0 notes