我正在使用angular2构建一个网站并使用ng2文件上传库ng2文件上传我想在选择图像后立即在我的网站上显示它。这个库怎么可能?
可以侦听onAfterAddingFile
事件并为本地 blob 创建 URL:
this.uploader = new FileUploader({url: '/your/url' });
this.uploader.onAfterAddingFile = (fileItem) => {
let url = (window.URL) ? window.URL.createObjectURL(fileItem._file) : (window as any).webkitURL.createObjectURL(fileItem._file);
this.localImageUrl = url
}
现在,您必须使用的img src存储在this.localImageUrl
中。问题是,当你尝试在DOM中使用它时,Angular会将其标记为不安全。要克服这个问题,您需要导入DomSanitizer
:
import { DomSanitizer } from '@angular/platform-browser';
并将其注入到组件的构造函数中:
export class MyComponent {
(...)
constructor(public sanitizer:DomSanitizer) {
(...)
}
最后,在模板中添加 img 的位置,使用清理器信任 url:
<img [src]="sanitizer.bypassSecurityTrustUrl(localImageUrl)">
遵循以下简单解决方案
import { DomSanitizer} from '@angular/platform-browser';
...
public previewPath: any;
....
constructor(private sanitizer: DomSanitizer) {
this.uploader.onAfterAddingFile = (fileItem) => {
this.previewPath = this.sanitizer.bypassSecurityTrustUrl((window.URL.createObjectURL(fileItem._file)));
}
}
在 html 中
<img [src]="previewPath " alt="Avatar" class="contribution-image">