我正在从API提取大量图像URL,并将它们显示在angular 2 Web应用程序中。一些网址已损坏,我想用存储在本地Web服务器上的默认图片替换它们。有没有人建议如何测试网址,并且在状态码404的情况下替换损坏的图片?
谢谢!
Answers:
监听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;
}
}
[default]='...'
图像中的a ,我将跳过它,并且您避免default
在每个<img>标签中添加。
您可以通过onError
这种方式使用事件来处理invalid url
或broken url
。
<img [src]="invalidPath" onError="this.src='images/angular.png'"/>
这样您可以通过onError事件将img路径直接分配给src
我关于角度4的示例
<img [src]="img" (error)="img.src = errorImg" #img>
我使用base64加载微调器:
<img [src]="photoContainer.photo.url | secure" onError="this.src=''">
完美的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>
如果要更改未加载的图像或源已损坏... Angular 8,只需更改此目标的默认资源的src:
组件HTML
<... [src] =“ person.pictureUrl”(错误)=“ pictNotLoading($ event)”>
组件TS
pictNotLoading(event){event.target.src ='assets / nopicture.png'; }
这是我针对多图像后备的解决方案。一旦解决了图像,我们基本上就分离了ChangeDetector,因此一旦解决了图像,我们就可以减少vm检查周期上的CPU。
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';
}
}
您可以为此用例简单地使用三元运算符。我假设您正在从远程服务器获取响应
<img src="{{ res.image ? res.image : onErrorFunction() }}"
如果您不想从服务器获取图像,请在路径中用单引号''引起来。
在这里,如果链接断开,则将转到onErrorFunction;如果未断开,将加载res.image。