Angular 2 - Проверьте правильность или нарушение URL-адреса изображения
Я извлекаю большое количество URL-адресов изображений из API и отображаю их в веб-приложении angular 2. Некоторые из URL-адресов повреждены, и я хочу заменить их изображением по умолчанию, которое хранится локально на моем веб-сервере. Есть ли у кого-нибудь предложение проверить URL-адреса, а в случае кода состояния 404 заменить сломанное изображение?
Спасибо!
Ответы
Ответ 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>