Jak*_*son 67 javascript angular
我从API获取大量图像URL并将其显示在角度2 Web应用程序中.一些URL被破坏,我想用我本地存储在我的网络服务器上的默认图片替换它们.有没有人有如何测试网址的建议,在状态代码404的情况下,更换损坏的图像?
谢谢!
Gün*_*uer 136
聆听error
图像元素的事件:
<img [src]="someUrl" (error)="updateUrl($event)">
Run Code Online (Sandbox Code Playgroud)
在哪里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;
}
}
Run Code Online (Sandbox Code Playgroud)
mic*_*yks 45
您可以通过onError
这种方式使用事件来处理invalid url
或broken url
.
<img [src]="invalidPath" onError="this.src='images/angular.png'"/>
Run Code Online (Sandbox Code Playgroud)
这样你就可以直接用onError事件将img路径分配给src
小智 17
我在角4的例子
<img [src]="img" (error)="img.src = errorImg" #img>
Run Code Online (Sandbox Code Playgroud)
我使用 base64 加载微调器:
<img [src]="photoContainer.photo.url | secure" onError="this.src=''">
Run Code Online (Sandbox Code Playgroud)
小智 5
我找到了一个对我有用的非常简单的解决方案。这不会检查404,但是我有可能具有和.image属性的对象。我知道这不是他的问题的答案,但希望它能帮助一些人。
<img class="list-thumb-img" [attr.src]="item.image?.url ? item.image.url : 'assets/img/140-100.png'">
Run Code Online (Sandbox Code Playgroud)
一个完美的 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);
}
}
Run Code Online (Sandbox Code Playgroud)
现在,HTML 将是:
<img [src]="'/some/valid-image.png'" appImage>
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
49999 次 |
最近记录: |