angular2 http get image 显示到页面

我们的server端会返回一个image/* (image/jpeg,image/png等等) 的图片对象,我预先定义了在http请求的入参中返回值的类型为blob

export interface RequestOptionsArgs {
    url?: string;
    method?: string | RequestMethod;
    search?: string | URLSearchParams;
    headers?: Headers;
    body?: any;
    withCredentials?: boolean;
    responseType?: ResponseContentType;
}
export declare enum ResponseContentType {
    Text = 0,Json = 1,ArrayBuffer = 2,Blob = 3,}

上图是angular的源代码,所以我的代码是根据blob来操作的

在typescript中需要将该对象解析,然后显示页面

页面部分:

<img [src]="imageData | safeUrl">

其中safeUrl是个过滤器,代码如下:

import { Pipe,PipeTransform } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';

@Pipe({
  name: 'safeUrl'
})
export class SafeUrlPipe implements PipeTransform {
  constructor(private domSanitizer: DomSanitizer) {}
  transform(url) {
    return this.domSanitizer.bypassSecurityTrustResourceUrl(url);
  }
}

为什么要加这个过滤器呢?下面会讲到

typescript部分:

getThumbnailImage(){
  this.service.getThumbnailImage(this.id,(resp)=>{
    let urlCreator = window.URL;
    this.imageData = urlCreator.createObjectURL(resp._body);
    console.log(this.imageData);
  });
}

这个函数的作用是通过id去获取server端的图片,resp是返回值,返回值中的_body就是图片对象,通过使用rulCreator的方法,可以得到一个blob:https的图片对象路径,但是这个blob路径在浏览器中会显示为unsafe,比如获取到的url为:blob:https://127.0.0.1/031c6651-7236-477f-99ae-44f775f9f17e,那么加在img标签src中的值为变为:unsafe:blob:https://127.0.0.1/031c6651-7236-477f-99ae-44f775f9f17e,这是angular的语法造成的,会自动为https等不安全链接加上前缀,这时候就需要使用angular的browser来去掉这个前缀,将去掉前缀的方法写成一个pipe这样简洁明了,使用方便

相关文章

AngularJS 是一个JavaScript 框架。它可通过 注:建议把脚本放在 元素的底部。这会提高网页加载速度,因...
angluarjs中页面初始化的时候会出现语法{{}}在页面中问题,也即是页面闪烁问题。出现这个的原因是:由于...
AngularJS 通过被称为指令的新属性来扩展 HTML。AngularJS 指令AngularJS 指令是扩展的 HTML 属性,带有...
AngularJS 使用表达式把数据绑定到 HTML。AngularJS 表达式AngularJS 表达式写在双大括号内:{{ expres...
ng-repeat 指令可以完美的显示表格。在表格中显示数据 {{ x.Name }} {{ x.Country }} 使用 CSS 样式为了...
$http是 AngularJS 中的一个核心服务,用于读取远程服务器的数据。读取 JSON 文件下是存储在web服务器上...