Skip to content

Instantly share code, notes, and snippets.

@seveves
Last active January 21, 2020 22:24
Show Gist options
  • Star 5 You must be signed in to star a gist
  • Fork 4 You must be signed in to fork a gist
  • Save seveves/5ce85c1083c7581c6423bc97e1a88297 to your computer and use it in GitHub Desktop.
Save seveves/5ce85c1083c7581c6423bc97e1a88297 to your computer and use it in GitHub Desktop.
Angular2 Show placeholder base64 image source till image is fully loaded
This component shows a smaller image or a base64 encoded image till the bigger version is fully loaded.
Added a blur/fade effect for the transition.
img.blur {
filter: blur(5px);
-webkit-filter: blur(5px);
-moz-filter: blur(5px);
-o-filter: blur(5px);
-ms-filter: blur(5px);
}
<div style="position: relative; left: 0; top: 0; width: 560px; height: 330px;">
<img [@fadeInOut]="fadeInState" class="blur" alt="placeholder" [src]="placeholder" style="position: relative; top: 0; left: 0; width: inherit; height: inherit;"/>
<img [@fadeInOut]="fadeOutState" alt="image" [src]="image" (load)="isLoaded($event)" style="position: absolute; top: 0px; left: 0px; width: inherit; height: inherit;"/>
</div>
import {
Component,
OnInit,
trigger,
state,
style,
transition,
animate
} from '@angular/core';
import { DomSanitizer, SafeUrl } from '@angular/platform-browser';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
animations: [
trigger('fadeInOut', [
state('in', style({opacity: 1, visibility: 'visible'})),
state('out', style({opacity: 0, visibility: 'hidden'})),
transition('in <=> out', [
animate('1s ease-out')
])
])
]
})
export class AppComponent implements OnInit {
public loaded = false;
public fadeInState = 'in';
public fadeOutState = 'out';
public isLoaded(event: Event) {
this.loaded = true;
this.fadeInState = 'out';
this.fadeOutState = 'in';
}
private _placeholderBase64 = ``;
private _placeholderImg = "/assets/bg-low.jpg";
private _imgSafe: SafeUrl;
private _placeHolderSafe: SafeUrl;
constructor(private sanitizer: DomSanitizer) {}
public get placeholder() {
return this._placeHolderSafe;
}
public ngOnInit() {
this._placeHolderSafe = this.sanitizer.bypassSecurityTrustUrl(this._placeholderBase64);
this._imgSafe = this.sanitizer.bypassSecurityTrustUrl("/assets/bg.jpg");
}
public get image() {
return this._imgSafe;
}
}
@yoelnacho
Copy link

yoelnacho commented Nov 8, 2017

HI.
app.component.ts - > 'loaded' is necessary?

@enginesoftsolutions
Copy link

Worked great. Thanks for your code!

@ikishanoza
Copy link

my Image is loaded first and then the placeholder is faded out .. looks like I have done something wrong.. can you please help me out ?
here is my code

import { Component, OnInit, ElementRef, 
  ViewChild, trigger, state, style, transition, 
  animate } from '@angular/core';
@Component({
  selector: 'app-manage-channel',
  templateUrl: './manage-channel.component.html',
  styleUrls: ['./manage-channel.component.scss'],
  animations: [
    trigger('fadeInOut', [
      state('in', style({display: 'block'})),
      state('out', style({display: 'none'})),
      transition('in <=> out', [
        animate('1s ease-out')
      ])
    ])
  ]
})
export class ManageChannelComponent implements OnInit {
  public loaded = false;
  public fadeInState = 'in';
  public fadeOutState = 'out';
  private _placeHolderSafe = "assets/img/favicon.png";
  public isLoaded(event: Event) {
    this.loaded = true;
    console.log("dsds");
    this.fadeInState = 'out';
    this.fadeOutState = 'in';
  }
  public get placeholder() {
    return this._placeHolderSafe;
  }
}


here is my html

<img [@fadeInOut]="fadeInState" class="blur" alt="placeholder" 
                  [src]="placeholder" width="80" height="80" />
                <img [@fadeInOut]="fadeOutState" [src]="item.channelLogo" onError="this.src = 'assets/img/no_img.png'" (load)="isLoaded($event)" width="80" height="80">

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment