首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Angular scrollPositionRestoration没有动画/平滑滚动?

Angular的scrollPositionRestoration属性用于控制页面导航后滚动位置的恢复方式。默认情况下,当页面导航后,滚动位置会被恢复到之前的位置,但没有动画或平滑滚动效果。

要实现具有动画或平滑滚动效果的滚动位置恢复,可以通过自定义导航器来实现。以下是一个示例:

  1. 创建一个自定义导航器类,例如SmoothScrollRestoration:
代码语言:txt
复制
import { Injectable } from '@angular/core';
import { Router, Scroll, ScrollBehavior } from '@angular/router';

@Injectable()
export class SmoothScrollRestoration implements ScrollBehavior {
  constructor(private router: Router) {}

  public shouldScroll = (position: Scroll): boolean => {
    return true;
  }

  public scrollToPosition = (position: Scroll): [number, number] => {
    const [x, y] = position.position;
    window.scrollTo({ top: y, left: x, behavior: 'smooth' });
    return [x, y];
  }

  public getScrollPosition = (): [number, number] => {
    return [window.scrollX, window.scrollY];
  }
}
  1. 在应用的根模块中提供自定义导航器:
代码语言:txt
复制
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { RouterModule, Router, Scroll } from '@angular/router';
import { SmoothScrollRestoration } from './smooth-scroll-restoration';

@NgModule({
  imports: [BrowserModule, RouterModule.forRoot([])],
  providers: [
    {
      provide: Scroll,
      useClass: SmoothScrollRestoration,
      deps: [Router],
    },
  ],
})
export class AppModule {}

现在,当使用Angular的路由导航时,滚动位置将具有平滑滚动效果。

关于Angular的scrollPositionRestoration属性和自定义导航器的更多信息,可以参考腾讯云的Angular文档:Angular文档

请注意,本回答中没有提及亚马逊AWS、Azure、阿里云、华为云、天翼云、GoDaddy、Namecheap、Google等流行的云计算品牌商,以符合要求。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券