2016-03-10 81 views
11

我正在處理angular2中的項目,它涉及從數據庫直接加載圖像(base64編碼)。在angular1中,可以簡單加載它如下:在angular2中顯示嵌入圖像

<img data-ng-src="data:image/jpg;base64,{{entry.img}}" /> 

其中entry.img是原始圖像數據。不過,我不知道如何在angular2中做到這一點。我試過

<img [src]="data:image/jpg;base64,{{entry.img}}" /> 

但是,這並不工作,因爲角仍嘗試從一個URL加載圖像。

回答

17

也許你可以試試這個:

<img [src]="'data:image/jpg;base64,'+entry.img" /> 

假設entry是組件的屬性,包含一個img屬性。

+0

解決我的恩德使用,thx。這樣做(使用base64)對性能有什麼影響? – user1019042

+1

你確定這可以嗎? Angular抱怨XSS問題並使用'unsafe:'前綴。我已閱讀的其他解決方案可以繞過安全措施。 – Mc128k

2

我用<img [attr.src]="image.base64">在我的模型看起來像這樣

export class ImageModel { 
    public alt:string = ""; 
    public name:string = ""; 
    public base64:string =''; 
} 

,但@Thierry的版本作品也。我附加了組件的一部分和一段html。也許你可以改善你的解決方案或改善煤礦:)

HTML

<div class="row"> 
    <div class="col-xs-12"> 
     <p class="f-500 c-black m-b-20">Image Preview</p> 

     <div class="fileinput fileinput-new" [ngClass]="{'fileinput-exists': fileExists(), 'fileinput-new': !fileExists()}"> 
      <div class="fileinput-preview thumbnail"> 
       <img *ngIf="fileExists()" [attr.src]="image.base64"> 
      </div> 
      <div> 
       <span class="btn btn-info btn-file"> 
        <span class="fileinput-new">Select image</span> 
        <span class="fileinput-exists">Change</span> 
        <input type="file" #fileInp (change)="onFileChange($event)" name="file"> 
       </span> 
       <a href="#" class="btn btn-danger fileinput-exists" (click)="clearImage($event)">Remove</a> 
      </div> 
     </div> 
    </div> 
</div> 

組件

///<reference path="../../../../../typings/tsd.d.ts"/> 

import {Component, OnInit} from 'angular2/core' 
import {Router} from 'angular2/router'; 
import {NgClass} from 'angular2/common'; 

import {ImageInterface} from './image.interface' 
import {ImageService} from './image.service' 
import {ImageModel as Image} from './image.model' 

import {ImageComponent} from './image.component' 

@Component({ 
    selector: 'create-images-component', 
    templateUrl: './angular2/app/images/image-form.component.html', 
    providers: [ 
     ImageService 
    ], 
    directives: [ 
     ErrorsComponent, 
     NgClass, 
    ] }) 

export class CreateImageComponent implements OnInit { 

    public image:ImageInterface = new Image(); 
    public validationErrors; 

    constructor(public service:ImageService, 
       private _router:Router) { 
    } 

    /** 
    * File input change event 
    * @param event 
    */ 
    onFileChange(event) { 
     let file = event.target.files[0]; 
     if (!file) { 
      return; 
     } 
     if (this.isValidExtension(file) == false) { 
      swal('Invalid file format!', 'Invalid file Format. Only ' + ImageComponent.ALLOWED_EXTENSIONS.join(', ') + ' are allowed.', 'error'); 
      return false; 
     } 
     if (this.isValidFileSize(file) == false) { 
      swal('Invalid file size!', 'Invalid file size. Max allowed is : ' + ImageComponent.ALLOWED_SIZE + ', your file is : ' + this.getFileSize(file) + ' Mb' , 'error'); 
      return; 
     } 
     console.log(file); 

     let reader = new FileReader(); 
     reader.onload = (e) => { 
      this.image.base64 = e.target.result; 
     }; 
     reader.readAsDataURL(file); 
    } 

    /** 
    * Check if file has valid extension 
    * @param file 
    */ 
    private isValidExtension(file:File):boolean { 
     let allowedExtensions = ImageComponent.ALLOWED_EXTENSIONS; 
     let extension = file.name.split('.').pop(); 
     return allowedExtensions.indexOf(extension) !== -1 
    } 

    /** 
    * Check file size 
    * @param file 
    * @returns {boolean} 
    */ 
    private isValidFileSize(file) { 
     let size = this.getFileSize(file); 
     return size < ImageComponent.ALLOWED_SIZE; 
    } 

    /** 
    * GEt file size in Mb 
    * @param file 
    * @returns {Number} 
    */ 
    private getFileSize(file:File):Number { 
     return file.size/1024/1024; 
    } 

    /** 
    * Clear selected image 
    * @param ev 
    */ 
    clearImage(ev) { 
     ev.preventDefault(); 
     this.image.base64 = '' 
    } 

    /** 
    * Return if image exists 
    * @returns {boolean} 
    */ 
    fileExists() { 
     return this.image.base64 && (typeof this.image.base64 !== 'undefined') 
    } 

    /** 
    * Create new image 
    */ 
    onSubmit(form) { 
     return this.service.httpPost(this.image) 
      .subscribe(
      (res) => { 
       if (res.data.errors) { 
        this.validationErrors = res.data.errors; 
       } 
       if (res.status == "success") { 
        this.successMessage = res.message; 
        swal("Good Job", res.message, "success"); 
        this.validationErrors = []; 
       } else { 
        this.errorMessage = res.message; 
       } 
      }, 
      (error) => this.errorMessage = <any>error); 
    } 

    onCancel() { 
     return this._router.navigate(['Images']); 
    } 

    get diagnostic() { 
     return JSON.stringify(this.image); 
    } 

} 

enter image description here