Guten Tag,
ich bin gerade dabei einen RecycleView zu basteln.
Kurz erklärt ich habe ein Array mit z.B. 100 HTMLElementen beim laden der Seite werden die ersten 8 Elemente in einem DIV angezeigt. Wenn der Benutzer nun nach unten scrollt und beim letzten Element angekommen ist wird das 1. Element aus dem DIV entfernt und am Ende wird ein neues Element hinzugefügt. Der DIV enthält also immer 8 Elemente wobei das erste und letzte Element von einem
Wenn ich in Firefox zum 20+ Element scrolle und anschließend wieder nach oben scrolle springt Firefox ungewollt zum 1. Element. Das Problem tritt nur in Firefox auf wenn man zu schnell nach oben scrollt.
Meine RecycleView Methode
Hat jemand eine Ahnung woran das liegen könnte oder noch besser eine Lösung für das Problem?
Ich hab das Projekt auch mal angehängt. Um das Verhalten zu reproduzieren einfach bis zum 20+ Element scrollen und dann 3x schnell mit dem Mausrad noch oben scrollen.
*Edit*
Bei genauerem betrachten des Problems fällt auf das FireFox die neu hinzugefügten Elemente in den Viewport scrollt. Als workaround stelle ich nun sicher das nach dem hinzufügen eines neuen Elements das 2. Element in den Viewport gescrollt wird. Das behebt das Problem.
ich bin gerade dabei einen RecycleView zu basteln.
Kurz erklärt ich habe ein Array mit z.B. 100 HTMLElementen beim laden der Seite werden die ersten 8 Elemente in einem DIV angezeigt. Wenn der Benutzer nun nach unten scrollt und beim letzten Element angekommen ist wird das 1. Element aus dem DIV entfernt und am Ende wird ein neues Element hinzugefügt. Der DIV enthält also immer 8 Elemente wobei das erste und letzte Element von einem
IntersectionObserver
überwacht werden.Wenn ich in Firefox zum 20+ Element scrolle und anschließend wieder nach oben scrolle springt Firefox ungewollt zum 1. Element. Das Problem tritt nur in Firefox auf wenn man zu schnell nach oben scrollt.
Quellcode
- #recycleViews(entries)
- {
- let hasIntersection = false;
- for(let i = 0; i < entries.length; ++i)
- {
- if (!entries[i].isIntersecting)
- continue;
- hasIntersection = true;
- const entry = entries[i];
- this.#intersectionObserver.unobserve(entry.target);
- if (entry.target === this.#observedTargets.firstTarget)
- {
- let index = this.#childElements.findIndex(x => x === this.#parentElement.firstElementChild);
- if (index < 1)
- continue;
- this.#parentElement.lastElementChild.remove();
- this.#parentElement.insertBefore(this.#childElements[--index], this.#parentElement.firstElementChild);
- this.#observedTargets.firstTarget = null;
- }
- else if (entry.target === this.#observedTargets.lastTarget)
- {
- let index = this.#childElements.findIndex(x => x === this.#parentElement.lastElementChild);
- if (index < 0 || index >= this.#childElements.length - 1)
- continue;
- this.#parentElement.firstElementChild.remove();
- this.#parentElement.appendChild(this.#childElements[++index]);
- this.#observedTargets.lastTarget = null;
- }
- }
- if (hasIntersection)
- this.#startObservation(this.#parentElement.firstElementChild, this.#parentElement.lastElementChild);
- }
Hat jemand eine Ahnung woran das liegen könnte oder noch besser eine Lösung für das Problem?
Ich hab das Projekt auch mal angehängt. Um das Verhalten zu reproduzieren einfach bis zum 20+ Element scrollen und dann 3x schnell mit dem Mausrad noch oben scrollen.
*Edit*
Bei genauerem betrachten des Problems fällt auf das FireFox die neu hinzugefügten Elemente in den Viewport scrollt. Als workaround stelle ich nun sicher das nach dem hinzufügen eines neuen Elements das 2. Element in den Viewport gescrollt wird. Das behebt das Problem.
Dieser Beitrag wurde bereits 1 mal editiert, zuletzt von „Fakiz“ ()