programing

Angular 2 - 이미지 URL이 유효하거나 손상되었는지 확인합니다.

magicmemo 2023. 7. 25. 20:51
반응형

Angular 2 - 이미지 URL이 유효하거나 손상되었는지 확인합니다.

나는 API에서 많은 이미지 URL을 가져와서 각도 2 웹 애플리케이션에 표시하고 있습니다.URL 중 일부가 손상되어 웹 서버에 로컬로 저장된 기본 사진으로 바꾸려고 합니다.URL을 테스트하고 상태 코드 404의 경우 손상된 이미지를 교체하는 방법을 제안하는 사람이 있습니까?

감사합니다!

들어보세요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;
  }
}

지시 플런커 예제

이벤트를 이 방법으로 사용하여 또는 를 처리할 수 있습니다.

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

이렇게 하면 onError 이벤트를 통해 img 경로를 src에 직접 할당할 수 있습니다.

각도 4에 대한 나의 예

<img [src]="img" (error)="img.src = errorImg" #img>
  1. 여기서 img - 이미지 경로;
  2. 오류 - 오류 발생
  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"(오류)="pictNotLoading($event)" >

  • 구성품 TS

    pictNotLoading(이벤트) {event.target.src = 'filename/noppicture.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>

이 사용 사례에는 단순히 3차 연산자를 사용할 수 있습니다.원격 서버에서 응답을 받고 있다고 가정합니다.

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

서버의 이미지를 원하지 않는 경우 경로를 작은따옴표 '로 작성합니다.

여기서 링크가 끊기면 링크가 끊기지 않으면 오류 기능이 실행됩니다. res.image가 로드됩니다.

언급URL : https://stackoverflow.com/questions/36429903/angular-2-check-if-image-url-is-valid-or-broken

반응형