背景图像未在 Angular 中显示

SK.*_*SK. 1 css sanitize typescript angular

是的,我确实搜索并找到了很多示例,但没有一个对我有用。我不确定我做错了什么。需要帮忙!

如果我放入<img>标签,我可以看到图像,但当我放入background-image. 但是当我检查元素时我可以看到二进制图像。

尝试在 stackblitz https://stackblitz.com/edit/display-image-from-rest-api-qpnspq?embed=1&file=src/app/app.component.ts 中做一个例子

HTML:

 <!-- This works -->
 <div class="row" style="max-width: 100%; margin-left: 1px;" >
     <img id="dashboardImage" [src]='imageBlobDataUrl' height='500' width='500' />
 </div>

 <!-- This does NOT works -->
<div class="row" style="max-width: 100%; margin-left: 1px;" [style.background-image]="image"> </div>
Run Code Online (Sandbox Code Playgroud)

TS:

    @Input() imageBlobDataUrl: any;
    selectedImage: QiImage = new QiImage();

    public header:SafeHtml;
    public content:SafeHtml[];
    public image:SafeStyle;

  constructor(
          private qiImageService: QiImageService,
          private sanitizer: DomSanitizer,
          private imageService: ImageService
  ) {}
  populateImageDetails(lineId, bitmapFileName) {
      this.imageService
          .populateImageDetails(lineId, bitmapFileName)
              .subscribe( (selectedImage : any) => {
                  this.selectedImage = selectedImage;
                  //let TYPED_ARRAY = new Uint8Array(selectedImage.imageData);
                  //const STRING_CHAR = String.fromCharCode.apply(null, TYPED_ARRAY);
                  //let base64String = btoa(STRING_CHAR);
                  let objectURL = 'data:image/png;base64,' + selectedImage.imageData;
                  this.imageBlobDataUrl = this.sanitizer.bypassSecurityTrustUrl(objectURL);
                  this.image = this.sanitizer.bypassSecurityTrustStyle(`url(${objectURL})`);
              });
  }
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

nir*_*aft 7

当我尝试你的stackblitz时它工作正常。您需要修复 CSS 才能在视图中显示图像。

不要bypassSecurityTrustUrl用于样式 URL。所以下面的缩略图无效:

this.thumbnail = this.sanitizer.bypassSecurityTrustUrl(objectURL); // Do NOT Use

this.image = this.sanitizer.bypassSecurityTrustStyle(`url(${objectURL})`); // This works fine and is Valid
Run Code Online (Sandbox Code Playgroud)

尝试调整图像的CSS 位置,它会显示出来:

<div class="row" 
  style="width: 100%; height: 100%; position:absolute; 
  margin-left: 1px;  background-repeat: no-repeat;" 
  [style.background-image]="image"> </div>
Run Code Online (Sandbox Code Playgroud)