如何在 Angular 的 Typescript 中使用数组

Posted

技术标签:

【中文标题】如何在 Angular 的 Typescript 中使用数组【英文标题】:How to use Arrays in Typescript in Angular 【发布时间】:2020-11-08 18:37:49 【问题描述】:

我编写了一个 Rest API,它返回一组数据,这些数据用于填充表单的 2 个下拉菜单。从 API 返回的数据是从 Angular 后端接收并绑定的到下拉菜单。我没有编写 2 个 Get 请求来获取 2 个表单的数据,而是尝试在一个 Get 中获取这些数据。

Java 后端 Get 方法

 @GetMapping("/flight/formdata")
    public List getWebSiteFormData() 

        List formDataSet=FligthtDataServices.getWebSiteFormData();
        return formDataSet;
    

Postman 上显示的数据集

[
    [
        "London Heathrow",
        "AP"
    ],
    [
        "Velana International Airport",
        "AP"
    ],
    [
        "Hamad International Airport",
        "AP"
    ],
    [
        "Suvarnabhumi Airport",
        "AP"
    ],
    [
        "Changi Airport",
        "AP"
    ],
    [
        "Business",
        "CL"
    ],
    [
        "Premium Economy",
        "CL"
    ],
    [
        "Economy",
        "CL"
    ]
]

服务类

  getWebSiteFormData():Observable<any>
    return this.http.get(`$this.baseUrl/formdata`);
  

我的方法是, 具有值“AP”的数据数组应该绑定到 Departure Airports 下拉列表,并且具有“CL”的数组应该显示在 Class Drop-down 中。所以我所做的是基于我试图划分该数据的这两个标识符分成 2 个数组 fromairportlist=[]; , flightclass=[];

预订组件

export class BookingComponent implements OnInit 
  
  public websiteformdata=[];
  public flightclass=[];
  public fromairportlist=[];

  constructor(private flightService:FlightService, private router: Router)  
  
  ngOnInit(): void 
  this.loadFormData();
  

  loadFormData()
    this.flightService.getWebSiteFormData().subscribe(data=>this.websiteformdata=data,error=>console.error(error)) 
   
   for (let item of this.websiteformdata) 
     if(item[1]=='AP')
       this.fromairportlist.push(item[0]);
        
    
   console.log(this.fromairportlist)
  


Booking.component.html 文件

 <td style="height: 39px; width: 14%;"> 
        <div class="input-group">
        <div class="input-group-prepend">
          <div class="input-group-text">Departure</div>
        </div>
       <select class="form-control" id="classtype" name="classtype" [(ngModel)]="booking.classtype">
        <option>fromairportlist[0]</option>
        <option>fromairportlist[1]</option>
        <option>fromairportlist[2]</option>
       </select>
       </div>
    </td>

但它似乎没有工作如图所示的下拉菜单中没有显示任何内容

如果我的方法有误,请提出纠正方法。

【问题讨论】:

【参考方案1】:

第一次使用*ngFor:&lt;option *ngFor="let option of fromairportlist"&gt; option &lt;/option&gt;

这可能会有所帮助 Angular 4 setting selected option in Dropdown

【讨论】:

【参考方案2】:

由于您的结果是一个字符串数组,因此通过 for 循环对其进行循环。很简单,

<select>
  <option *ngFor="let item of fromairportlist">item</option>
</select>

如果有任何疑问,请参阅您的参考的 stackblitz 解决方案。 https://stackblitz.com/edit/angular-m2kfec

【讨论】:

以上是关于如何在 Angular 的 Typescript 中使用数组的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Angular 5 中从 Typescript 调用 JavaScript 函数?

如何在对象数组中显示特定对象(Angular 5,TypeScript)

如何在 Angular 2 的 TypeScript 中映射嵌套的 Json

Typescript - 如何在 Angular2 中正确使用 jsPDF?

如何在ASP.NET 5上搭建基于TypeScript的Angular2项目

如何在 Angular2 Typescript 中返回多个值