Angularmat-autocomplete无法使用通过函数返回的选项。
创始人
2024-10-28 06:31:05
0

在使用mat-autocomplete时,如果选项是通过调用函数来返回的,则需要在函数返回之前将选项放入一个数组中。这样mat-autocomplete才能够正确地使用它们。

以下是示例代码:

在component.ts文件中,定义一个函数来返回选项。该函数首先调用一个API来获取选项,然后将选项放入数组中,最后返回该数组:

import { Component } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs/Observable';
import { map } from 'rxjs/operators';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  optionList: any[] = [];

  constructor(private http: HttpClient) {}

  getOptions(keyword: string): Observable {
    return this.http.get(`https://api.example.com/options?keyword=${keyword}`).pipe(
      map((result: any) => {
        this.optionList = result.options; // 将选项放入数组中
        return this.optionList;
      })
    );
  }
}

在component.html文件中,使用mat-autocomplete时,使用ng-template对返回的选项进行循环。这里的options是一个本地变量,它保存了mat-autocomplete使用的选项数组。然后,调用getOptions函数来获取选项:


  
  
    
      {{ option }}
    
  

然后,在component.ts文件中,在函数返回中调用mat-autocomplete的update方法,传递选项数组作为参数:

import { Component } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { Observable } from 'rxjs/Observable';
import { map } from 'rxjs/operators';
import { MatAutocomplete } from '@angular/material';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  optionList: any[] = [];

  constructor(private http: HttpClient) {}

  getOptions(keyword: string, autocomplete: MatAutocomplete): Observable {
    return this.http.get(`https://api.example.com/options?keyword=${keyword}`).

相关内容

热门资讯

轻量版八分钟!wepoke有挂... 轻量版八分钟!wepoke有挂网上德州微扑克辅助(其实真的有挂)-知乎1、用户打开应用后不用登录就可...
挂一分钟!来玩德州app服务器... 挂一分钟!来玩德州app服务器在哪里德州aa辅助(果真真的有挂)-今日头条小薇(透视辅助)致您一封信...
插件1分钟!wpk ai是有w... 插件1分钟!wpk ai是有wopoker德州真的有挂(的确真的有挂)-哔哩哔哩1、完成wopoke...
安卓版本6分钟!轰趴大菠萝十三... 安卓版本6分钟!轰趴大菠萝十三水辅助德州ai智能辅助(果然真的有挂)-知乎1、轰趴大菠萝十三水辅助系...
ai辅助五分钟!微扑克的辅助工... 您好,云扑克是否有外挂这款游戏可以开挂的,确实是有挂的,需要了解加微【487309276】很多玩家在...
新版八分钟!aapoker辅助... 新版八分钟!aapoker辅助工具wpk俱乐部有外挂(好像真的有挂)-小红书1、下载好wpk俱乐部有...
安卓版九分钟!德州之星辅助we... 安卓版九分钟!德州之星辅助wepoke ai辅助(果然真的有挂)-微博客户端;1)德州之星辅助辅助挂...
渠道八分钟!pokernow可... 渠道八分钟!pokernow可以加注德州ai辅助神器(其实真的有挂)-小红书;1、让任何用户在无需p...
最新款7分钟!gg扑克辅助we... 最新款7分钟!gg扑克辅助wepoke模拟器(果然真的有挂)-百度知乎;1、打开软件启动之后找到中间...
安装1分钟!nzt德州辅助软件... 安装1分钟!nzt德州辅助软件微扑克辅助软件(都是真的有挂)-百度知乎;1、点击下载安装,微扑克辅助...