1

我有一个像这样的json响应

 {
      _id: '5dd0d0dc4db1cf9c77781aaa',
      picture: 'http://placehold.it/32x32',
      name: 'Graciela Mcmahon',
      guid: '98c0fcc2-1dfc-4974-bdae-d8263d783e0a',
      star:
        '<mat-icon>star</mat-icon><mat-icon>star</mat-icon><mat-icon>star_half</mat-icon><mat-icon>star_border</mat-icon><mat-icon>star_border</mat-icon>',
 }

当我渲染开始时,它没有按预期渲染我的组件代码

<owl-carousel-o [options]="listingSliderOptions" class="row">
    <ng-container *ngFor="let listing of listingJson">
      <ng-template carouselSlide [id]="listing._id">
        <a [routerLink]="['/']" class="listing-grid-item">
          <figure>
            <img src="{{listing.picture}}" alt="" />
            <div class="info">
              <div class="cat_star" [innerHTML]="listing.star">

              </div>
              <h3>{{listing.name}}</h3>
            </div>
          </figure>
        </a>
      </ng-template>
    </ng-container>
  </owl-carousel-o>

上面的代码显示为 在此处输入图像描述

这是正确的显示方式还是我必须在 Angular 组件中生成标签?

预期结果

在此处输入图像描述

4

1 回答 1

2

问题

您的问题源于您尝试在运行时动态加载组件的事实。这不能指望纯 html 发生。

在此处阅读本文以了解动态组件加载。mat-icon不是 html 元素,因此浏览器不知道如何处理它,因此您会得到这个奇怪的结果。

在您的应用程序中加载来自 api 的 html 也是一种非常糟糕的安全做法,因为可能会注入恶意代码和 html。

解决方案

从您的后端将星星作为数字发送。创建一个 ngFor 并在其中定义 mat-icon 并迭代任意多次以创建星星。

<div class="cat_star">
      <ng-container *ngFor="let star of listing.star">
          <mat-icon>{{ star }}</mat-icon>
      </ng-container>
 </div>
于 2019-11-17T08:30:42.433 回答