Angular虚拟滚动显示问题
创始人
2024-10-30 10:31:02
0

在Angular中使用虚拟滚动时,有时候会遇到显示问题。这些问题通常是出现在滚动中的元素大小不一致的情况下。在此情况下,因为使用了虚拟滚动,所以只有少量的元素会被渲染。这样的话,它们的大小会影响渲染出来的元素的数量。

为了解决这个问题,我们可以对VirtualScrollStrategy进行扩展,在该扩展中,我们可以实现自己对ElementRef和ViewContainerRef的处理方式,从而确保元素会正确的被渲染出来。以下是一个示例:

import {CollectionViewer, DataSource, ListRange} from '@angular/cdk/collections';
import { BehaviorSubject, Observable, of } from 'rxjs';
import {catchError, finalize} from 'rxjs/operators';
import { ElementRef, Injectable, OnDestroy, ViewContainerRef } from '@angular/core';
import { CdkVirtualScrollViewport, VirtualScrollStrategy } from '@angular/cdk/scrolling';

@Injectable()
export class CustomVirtualScrollStrategy implements VirtualScrollStrategy, OnDestroy {
  private indexChange = new BehaviorSubject(0);
  private dataStream = new BehaviorSubject([]);
  private pooledPages = new Map();

  private viewRef: any;

  private snappedIndex = 0;

  constructor(private elementRef: ElementRef, private viewContainer: ViewContainerRef) {
    this.elementRef.nativeElement.style.overflow = 'auto';
  }

  ngOnDestroy(): void {}

  scrolled(index: number): void {
    const snappedIndex = this.getSnappedIndex(index);
    if (this.snappedIndex !== snappedIndex) {
        this.snappedIndex = snappedIndex;
        const maxIndex = this.viewRef.getDataLength() - 1;
        const start = Math.max(0, this.snappedIndex - 20);
        const end = Math.min(this.snappedIndex + 20, maxIndex);
        const pages = new Set();
        for (let i = start; i <= end; i++) {
            const pageIndex = Math.floor(i / this.viewRef.getPageSize());
            pages.add(pageIndex);
        }
        pages.forEach(page => this.fetchPage(page));
    }
  }

  attach(viewRef: any): void {
    this.viewRef = viewRef;
    this.viewContainer.createEmbeddedView(viewRef.templateRef);
  }

  detach(): void {
    this.viewContainer.clear();
    this.viewRef = null;
  }

  onDataLengthChanged(): void {
    this.indexChange.next(this.getAdjustedIndex(this.sn

相关内容

热门资讯

第6分钟实锤!德扑之星ai代打... 第6分钟实锤!德扑之星ai代打(wepower德州)竟然是有挂(详细辅助透明教程);亲,关键说明,德...
6分钟实锤!智星德州菠萝(德扑... 6分钟实锤!智星德州菠萝(德扑)竟然是有挂(详细辅助大神讲解)小薇(透视辅助)致您一封信;亲爱智星德...
第二分钟实锤!智星德州菠萝偷偷... 第二分钟实锤!智星德州菠萝偷偷看牌功能(来玩德州app)真是是真的有挂(详细辅助可靠教程)1、下载好...
第2分钟实锤!德州免费辅助神器... 第2分钟实锤!德州免费辅助神器app(德州wepower)一贯是真的有挂(详细辅助专业教程);1、游...
第5分钟实锤!德扑之星辅助器购... 第5分钟实锤!德扑之星辅助器购买(wepower德州)一直存在有挂(详细辅助2025新版教程)1、打...
八分钟实锤!德州之星外挂(德州... 八分钟实锤!德州之星外挂(德州)本来存在有挂(详细辅助解密教程)一、德州之星外挂AI软件牌型概率发牌...
第六分钟实锤!德州微扑克辅助(... 第六分钟实锤!德州微扑克辅助(德州app)都是存在有挂(详细辅助软件教程)德州微扑克辅助是一种具有地...
第4分钟实锤!智星德州菠萝偷偷... 第4分钟实锤!智星德州菠萝偷偷看牌功能(德州之星)本来有挂(详细辅助系统教程)1、玩家可以在智星德州...
两分钟实锤!德州免费辅助神器a... 两分钟实锤!德州免费辅助神器app(线上wpk德州)其实是有挂(详细辅助教你攻略)1、让任何用户在无...
七分钟实锤!德州微扑克辅助(来... 七分钟实锤!德州微扑克辅助(来玩德州app)本来有挂(详细辅助2025新版)一、德州微扑克辅助AI软...