在 Angular 7 中,我无法将动态图像显示为 [style.background-image]

Posted

技术标签:

【中文标题】在 Angular 7 中,我无法将动态图像显示为 [style.background-image]【英文标题】:In Angular 7, I can't display a dynamic image as [style.background-image] 【发布时间】:2019-11-15 12:13:28 【问题描述】:

在我的 Angular 应用程序中,我从后端加载动态背景图像。

显示图片不是问题。

背景图片未加载,遗憾的是我没有收到错误消息。

我的 Angular 版本是 7.3.8。

我尝试了一些来自 *** 和网络的解决方案,但没有任何帮助

布局 - html

  <div *ngIf="headerImage" [style.background-image]="headerImage">

布局-组件:

  ngOnInit() <br/>
      this.setup = this.route.snapshot.data['setup'];
      this.createHeader(this.setup)
    

   createHeader(setup: Setup)
      const tempImage = 'data:image/png;base64,' + this.setup.headerImage.data;
      this.headerImage = this.sanitizer.sanitize(SecurityContext.STYLE, 'url(' + tempImage + ')');
      console.log(this.headerImage);
      

我的控制台的输出:

  this.headerImage console.log: url(data:image/png;base64,iVBORw0KGgo.......

我试过了

   [ngStyle]="'background-image':' url(' + headerImage + ')'"

还有这个

   this.backgroundImg = sanitizer.bypassSecurityTrustStyle('url(....)'

但没有任何效果。

我不知道,会发生什么?我没有收到错误消息并且显示图像不是问题...但我需要背景。

谢谢帮助!

【问题讨论】:

检查这个:***.com/q/34875426/2050306 我已经试过了:/ 也许你应该提供一个 plunkr ... 【参考方案1】:

看起来你做的一切都是正确的,你应该尝试确保没有可能导致问题的外部因素,也许元素没有大小?你试过不同的图像吗?您是否尝试过设置background: url(...) 而不是backround-image: url(...)。请记住,css 样式继承可能会覆盖您的内容。

【讨论】:

可能元素没有大小?

以上是关于在 Angular 7 中,我无法将动态图像显示为 [style.background-image]的主要内容,如果未能解决你的问题,请参考以下文章

使用 Angular 7 从 Firebase 存储中检索图像

如何在javascript中动态添加图像[关闭]

在 Angular 7 运行时动态生成 CSS 类

从 MongoDB 在 Angular.js 中显示图像

无法显示 Angular 下资产部分中列出的某些图像

Angular 2 - 使用 ngStyle 将背景图像转换为 html 文件