Ng-lazyload-image: Funktioniert nicht mit eckigen 5

Erstellt am 9. Nov. 2017  ·  4Kommentare  ·  Quelle: tjoskar/ng-lazyload-image

Hallo, ich habe diese Lib in Angular 5 ausprobiert, konnte sie aber nicht zum Laufen bringen. Ich habe so eine Komponentenvorlage

<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>

und so eine komponente

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() {
  }

}

Und mein Modul

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 {
}

Das Bild wird einfach nie angezeigt. Ich bekomme diese Warnmeldung auch in der Konsole

image

Ich bin mir nicht sicher, was ich falsch mache. Jede Hilfe geschätzt

Hilfreichster Kommentar

Entschuldigen Sie. Ich habe mir mein Problem genauer angesehen und es stellte sich heraus, dass ich dieses CSS-Stück hatte, das alle Scroll-Ereignisse im Browser zu deaktivieren schien

html, body {
  overflow-x: hidden;
}

Um dies zu umgehen, habe ich dieses benutzerdefinierte Scroll-Ereignis wie folgt hinzugefügt

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() {
  }

}

und in meiner Vorlage so

<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>

Jetzt funktioniert es perfekt in eckigen 5

Alle 4 Kommentare

Hallo @el-davo,

Danke für den Bericht. Verwenden Sie ein Server-Rendering? Oder Ihre App vorkompilieren? Oder führst du die App im Entwicklungsmodus aus?

Hallo. Nein, ich mache kein serverseitiges Rendering. Ja, derzeit im Dev-Modus mit dem Angular-Cli

Welchen Browser verwendest du?
Ich habe gerade eine neue eckige App mit dem cli (Angular 5) erstellt und konnte diese nicht reproduzieren. Ich habe folgende Änderungen vorgenommen:

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 { }

Ich habe auch einen plnkr erstellt (https://embed.plnkr.co/rr046QU9YYWALdX7Xzf6/), konnte den Fehler aber nicht reproduzieren.
Glaubst du, du könntest ein kleines Git-Repo oder einen plnkr erstellen, um den Fehler zu reproduzieren?

Entschuldigen Sie. Ich habe mir mein Problem genauer angesehen und es stellte sich heraus, dass ich dieses CSS-Stück hatte, das alle Scroll-Ereignisse im Browser zu deaktivieren schien

html, body {
  overflow-x: hidden;
}

Um dies zu umgehen, habe ich dieses benutzerdefinierte Scroll-Ereignis wie folgt hinzugefügt

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() {
  }

}

und in meiner Vorlage so

<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>

Jetzt funktioniert es perfekt in eckigen 5

War diese Seite hilfreich?
0 / 5 - 0 Bewertungen

Verwandte Themen

lares83 picture lares83  ·  3Kommentare

sandeepdussa picture sandeepdussa  ·  9Kommentare

coryrylan picture coryrylan  ·  7Kommentare

philipgiuliani picture philipgiuliani  ·  11Kommentare

stratio84 picture stratio84  ·  6Kommentare