Подтвердить что ты не робот

Angular 2 - Проверьте правильность или нарушение URL-адреса изображения

Я извлекаю большое количество URL-адресов изображений из API и отображаю их в веб-приложении angular 2. Некоторые из URL-адресов повреждены, и я хочу заменить их изображением по умолчанию, которое хранится локально на моем веб-сервере. Есть ли у кого-нибудь предложение проверить URL-адреса, а в случае кода состояния 404 заменить сломанное изображение?

Спасибо!

4b9b3361

Ответ 1

Слушайте событие error элемента изображения:

<img [src]="someUrl" (error)="updateUrl($event)">

где updateUrl(event) { ... } присваивает новое значение this.someUrl.

Пример плунжера

Если вы хотите только проверить код, вы можете использовать метод, описанный в Проверка наличия изображения с помощью javascript

@Directive({
  selector: 'img[default]',
  host: {
    '(error)':'updateUrl()',
    '[src]':'src'
   }
})
class DefaultImage {
  @Input() src:string;
  @Input() default:string;

  updateUrl() {
    this.src = this.default;
  }
}

Пример директивы Plunker

Ответ 2

Вы можете использовать onError событие таким образом, чтобы обрабатывать invalid url или broken url.  

<img [src]="invalidPath" onError="this.src='images/angular.png'"/> 

Таким образом вы можете напрямую назначить путь img к src с событием onError

Ответ 3

Мой пример на angular 4

<img [src]="img" (error)="img.src = errorImg" #img>
  • Где img - путь к изображению;
  • ошибка - ошибка emmit
  • errorImg - путь к умолчанию img
  • #img - ссылка на объект img

Ответ 4

Я нашел очень простое решение, которое сработало для меня. Это не проверяет 404, однако у меня были объекты, которые, возможно, имели атрибут .image. Я знаю, что это не ответ на его вопрос, но, надеюсь, он помогает кому-то там.

<img class="list-thumb-img" [attr.src]="item.image?.url ? item.image.url : 'assets/img/140-100.png'">

Ответ 5

Я использую загрузчик base64:

<img [src]="photoContainer.photo.url | secure" onError="this.src=''">

Ответ 6

Это мое решение для резервного копирования на несколько изображений. мы в основном отсоединяем ChangeDetector после того, как мы разрешим изображение, чтобы мы могли сократить количество циклов процессора на vm после разрешения изображения.

import {Component, ChangeDetectionStrategy, ChangeDetectorRef} from 'angular2/core';
import {AppStore} from "angular2-redux-util/dist/index";



@Component({
    selector: 'logoCompany',
    changeDetection: ChangeDetectionStrategy.Default,
    template: `
            <div style="padding-top: 7px" > 
              <span style="color: gainsboro; font-family: Roboto">{{getBusinessInfo('companyName')}}</span>
              <!--<img style="width: 35px" class="img-circle" src="http://galaxy.example.me/Resources/Resellers/{{getBusinessInfo('businessId')}}/{{getBusinessInfo('fileName')}}" />-->
              <img style="width: 35px" class="img-circle" [src]="getImageUrl()" (load)="onImageLoaded()" (error)="onImageError()" />
            </div>
    `
})

export class LogoCompany {

    constructor(private cdr:ChangeDetectorRef) {    
    }
    private imageRetries:number = 0;
    private unsub;


    private detach() {
        this.cdr.detach();
    }

    private getImageUrl() {          
        var url = '';
        switch (this.imageRetries){
            case 0: {
                url = 'http://galaxy.example.me/Resources/Resellers/' + this.getBusinessInfo('businessId') + '/Logo.jpg'
                break;
            }
            case 1: {
                url = 'http://galaxy.example.me/Resources/Resellers/' + this.getBusinessInfo('businessId') + '/Logo.png'
                break;
            }
            default: {
                url = 'assets/person.png'
                break;
            }

        }
        return url;
    }

    private onImageLoaded() {
        this.detach();
    }

    private onImageError() {
        this.imageRetries++;
    }

    private getBusinessInfo(field):string {
          return '12345';
    }





}

Ответ 7

Идеальная директива Angular 8:

import {AfterViewInit, Directive, ElementRef, Input} from '@angular/core';

@Directive({
    selector: '[appImage]'
})
export class ImageDirective implements AfterViewInit {

    @Input() src;

    constructor(private imageRef: ElementRef) {
    }

    ngAfterViewInit(): void {
        const img = new Image();
        img.onload = () => {
            this.setImage(this.src);
        };

        img.onerror = () => {
            // Set a placeholder image 
            this.setImage('assets/placeholder.png');
        };

        img.src = this.src;
    }

    private setImage(src: string) {
        this.imageRef.nativeElement.setAttribute('src', src);
    }
}

Теперь HTML будет:

<img [src]="'/some/valid-image.png'" appImage>