首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用ng-模板只显示在角10的博客中的相关条目。

使用ng-模板只显示在角10的博客中的相关条目。
EN

Stack Overflow用户
提问于 2021-12-14 23:24:22
回答 1查看 69关注 0票数 3

我有一个用Strapi制作的博客后端,您可以在其中添加一些内容类型,比如标题字段、描述字段和内容字段。如果博客是否相关,我还需要设置一个布尔内容类型。我设置了一个ngFor来显示我所有的博客条目,但我只想显示相关的条目。实际上,我使用ngIf指令显示了相关的内容,但是角为非相关条目留出了一些空白。有没有办法去除这些空白??我想这一定是带有ng模板的东西。

这是我的html,在这里我设置了我的ngFor:

代码语言:javascript
复制
<div class="col-md-6 col-xs-12" *ngFor="let data of datas; index as i"accesskey="">                                                    
    <div class="banner-wrapper" *ngIf='data?.relevante==True; else relevante'>
        <ng-template #myrelevante></ng-template>
        <a [routerLink]="['/pagina',data.id]" title="Leveling up in CSS">
            <div class="banner-wrapper-content">
                <h1 class="h2">{{ data.title }}</h1>
                <!-- <span class="category-tag category-tag-white"></span> -->
                <h3 class="mylittle">{{ data.description }}</h3>
                <time datetime="2016-01-18" class="">{{ data.fecha | date:'dd/MM/yyyy' }}</time>
            </div>
        </a>
        <img class="img-fluid"
                 src="http://localhost:1337{{ data.image.url }}"
                 alt="foto"
                 width="100%" 
                 data-rjs="2"
        />
    </div>
</div>

这是一幅图片,它显示了非相关博客条目的空白:

我也分享我的ts文件:

代码语言:javascript
复制
import { Component, OnInit } from '@angular/core';
import { Meta, Title } from '@angular/platform-browser';
import { StrapiService } from '../../../services/strapi.service';

import { Router } from '@angular/router';


@Component({
  selector: 'app-blog',
  templateUrl: './blog.component.html',
  styleUrls: ['./blog.component.scss']
})
export class BlogComponent implements OnInit {

  datas:any=[];
  errores:string="";
  totalLength:any;
  page:number = 1;

  constructor(
    private title: Title,
    private meta: Meta,
    public strapiserv:StrapiService,
    private router: Router
  ) { }

  ngOnInit(): void {

    this.title.setTitle('Blog');
    this.meta.updateTag({ 
      name: 'description', 
      content: 'Publicaciones más relevantes del mundo cloud, transformación digital y el mundo empresarial' 
    })
    this.meta.updateTag({
      name: 'keywords',
      content: 'Transformacion digital, Cloud, La nube, GCP, trabajo remoto, eSource capital, migración de datos, CSS, 2021, Navent, Google Cloud, Microsoft, Ciberseguridad'
    })


    this.strapiserv.getData().subscribe(res=>{

        this.datas= res as string[];

        this.totalLength = res.length;

    }, error =>{
      console.log(error);
        if(error.status == 0){
            this.errores="Código del error: "+error.status+" \n Ha ocurrido un error del lado del cliente o un error de red.";
        }else{
            this.errores="Código del error: "+error.status+"\n\n"+error.statusText;
        }
    })  


  }


  filterRelevante(datas: Data[]) : Data[] {
      return datas.filter(data => data.relevante)
  }


}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-15 22:45:07

您可以编写一个函数,该函数接受数据数组并返回筛选后的数据数组。

在.ts中:

代码语言:javascript
复制
filterRelevante(datas: Data[]) : Data[] {
    return datas.filter(data => data.relevante)
}

然后,您只需使用该函数将“数据”包装在模板中即可。

在您的html中:

代码语言:javascript
复制
<div 
    class="col-md-6 col-xs-12"
    *ngFor="let data of filterRelevante(datas); index as i"accesskey="">

我只是假设这里的数据类型是数据,但情况可能并非如此。这也是一个不好的名字,但是我喜欢在类型记录中输入东西,所以我建议为您的数据编写自己的接口,并正确命名它,而不是只使用任何。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70356723

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档