可以使用虚拟滚动来优化数据加载,以减少加载时间。以下是示例代码(假设使用Angular Material库中的mat-select组件):
import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
@Component({ selector: 'app-select-options', templateUrl: './select-options.component.html', styleUrls: ['./select-options.component.scss'] }) export class SelectOptionsComponent implements OnInit { // options数组包含所有可选项 options: string[] = []; // 用于跟踪选择的选项 selectedOptions = new FormControl([]); // 虚拟滚动视口 @ViewChild(CdkVirtualScrollViewport) viewPort: CdkVirtualScrollViewport;
constructor() { }
ngOnInit() { // 模拟生成选项 for (let i = 0; i < 1000; i++) { this.options.push('Option ' + i); } // 给视口设置初始渲染点 this.viewPort.scrollToIndex(0); }
// 选择框打开时调用 onSelectOpen() { // 视口重新渲染 this.viewPort.checkViewportSize(); this.viewPort.checkRenderedContent(); // 给视口重置初始渲染点 this.viewPort.scrollToIndex(0); }
// 选择框关闭时调用 onSelectClose() { // 视口重置 this.viewPort.scrollToIndex(0); }