Angular 2-检查图像url是否有效或已损坏



我从API获取大量图像URL,并将它们显示在angular 2 web应用程序中。有些URL已损坏,我想用本地存储在Web服务器上的默认图片替换它们。有人建议如何测试url,并在状态代码404的情况下替换损坏的图像吗?

谢谢!

监听图像元素的error事件:

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

其中CCD_ 2向CCD_。

Plunker示例

如果你只想签入代码,你可以使用javascript 检查图像是否存在中解释的方法

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

指令Plunker示例

您可以通过这种方式使用onError事件来处理invalid urlbroken url

  • https://plnkr.co/edit/fD8zxd?p=preview
<img [src]="invalidPath" onError="this.src='images/angular.png'"/> 

通过这种方式,您可以通过onError事件直接将img路径分配给src

我在angular 4 上的例子

<img [src]="img" (error)="img.src = errorImg" #img>
  1. 其中img-图像的路径
  2. error-error emmit
  3. errorImg-默认img的路径
  4. #img-指向img对象的链接

我使用base64加载微调器:

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

我找到了一个非常简单的解决方案。这不检查404,但我有可能具有和.image属性的对象。我知道这不是他的问题的答案,但希望它能帮助一些人。

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

一个完美的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"(error)="pictNotLoading($event)">

  • 组件TS

    pictNotLoading(事件){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';
    }


}

只有当url不正确时才会发生错误事件,如果url是正确的,但文件不存在,你可以在这个代码中使用

javascript检查服务器上是否存在文件:

(注意404是一个数字而不是字符串)

function doesFileExist(urlToFile) {
var xhr = new XMLHttpRequest();
xhr.open('HEAD', urlToFile, false);
xhr.send();
 
if (xhr.status == 404) {
    return false;
} else {
    return true;
}}

监听图像元素的(error)事件&如果图像被破坏,你可以隐藏图像本身:

<img #image src="..." (error)="image.hidden = true" [hidden]="image.hidden">

或任何其他元素:

<div [hidden]="image.hidden"></div>

或者完全删除任何div:

<div *ngIf="!image.hidden"></div>

或者在使用*ngFor:时

<div *ngFor="let some of somethings">
   <div *ngIf="some.imageUrl" class="image-class-1 img-class-2">
     <img src="{{some.imageUrl}}" (error)="some.imageUrl = null"/>
   </div>
</div>

您可以简单地为这个用例使用一个三元运算符。我假设您正在从远程服务器获得响应

<img src="{{ res.image ? res.image : onErrorFunction() }}"

如果您不想从服务器获得图像,请用单引号"写下路径。

在这里,如果链接断开,它将转到onErrorFunction。如果它没有断开,则将加载res.image。

最新更新