Angular中如何在点击按钮时导航到另一个组件中的特定div?
创始人
2024-10-31 16:00:45
0

首先,在目标组件中添加一个id为“myDiv”的div元素以便我们在其他组件中引用它。

This is my target div

接下来,在源组件中,我们需要导入Router和ActivatedRoute模块,并注入它们。

import { Router, ActivatedRoute } from '@angular/router';
...
constructor(private router: Router, private activatedRoute: ActivatedRoute) {}

然后,在按钮的点击事件处理函数中,我们可以通过以下方式导航到目标组件并滚动到目标div。

onButtonClick() {
  this.router.navigate(['target-component'], { 
    queryParams: { 
      scrollTo: 'myDiv' 
    },
    relativeTo: this.activatedRoute 
  });
}

在以上代码中,我们使用Routernavigate方法来导航到目标组件,我们可以通过queryParams来传递滚动的目标点,这里我们将scrollTo的值设置为“myDiv”。

同时,我们需要使用ActivatedRoute来指定目标组件是相对于当前组件进行导航的。最后,我们需要在目标组件的ngAfterViewInit中获取scrollTo参数并将屏幕滚动到目标div。

ngAfterViewInit() {
  this.activatedRoute.queryParams.subscribe(params => {
    const element = document.getElementById(params.scrollTo);
    if (element) {
      element.scrollIntoView({ behavior: 'smooth' });
    }
  });
}

在这里,我们使用ActivatedRoute模块中的queryParams,以获取在导航命令中传递的scrollTo参数值。我们使用document.getElementById()方法找到目标div并使用scrollIntoView({ behavior: 'smooth' })方法滚动到目标div。

当我们点击源组件中的按钮时,在导航到目标组件后,屏幕将自动滚动到id="myDiv"的div元素。

相关内容

热门资讯

反观!玉海楼辅助器,好像存在有... 反观!玉海楼辅助器,好像存在有辅助软件(有挂辅助)-哔哩哔哩1.玉海楼辅助器 选牌创建新账号,点击进...
据文件显示!汇友游戏辅助,本来... 据文件显示!汇友游戏辅助,本来真的是有辅助app(有挂细节)-哔哩哔哩据文件显示!汇友游戏辅助,本来...
最终!途游四川小程序脚本辅助,... 最终!途游四川小程序脚本辅助,确实有挂辅助插件(有挂工具)-哔哩哔哩1、下载好途游四川小程序脚本辅助...
近期!wepoker辅助器是真... 近期!wepoker辅助器是真的吗,都是有挂辅助软件(果真有挂)-哔哩哔哩1、wepoker辅助器是...
现有说明如下!广东雀神智能插件... 现有说明如下!广东雀神智能插件免费,一直真的是有辅助脚本(有挂技巧)-哔哩哔哩1、广东雀神智能插件免...
针对!都莱软件安装辅助,好像存... 针对!都莱软件安装辅助,好像存在有辅助软件(有挂辅助)-哔哩哔哩1、进入到都莱软件安装辅助是否有挂之...
相较于以往!情怀辅助器,果然有... 相较于以往!情怀辅助器,果然有挂辅助app(有挂头条)-哔哩哔哩1、进入游戏-大厅左侧-新手福利-激...
受玩家影响!微乐小程序免费黑科... 受玩家影响!微乐小程序免费黑科技,总是有挂辅助软件(有挂方针)-哔哩哔哩微乐小程序免费黑科技脚本下载...
最终!人皇辅助软件下载,真是是... 最终!人皇辅助软件下载,真是是真的辅助修改器(有挂方略)-哔哩哔哩;1、最终!人皇辅助软件下载,真是...
今年以来!拼三张自建房软件,一... 今年以来!拼三张自建房软件,一贯是有辅助平台(真实有挂)-哔哩哔哩1、该软件可以轻松地帮助玩家将拼三...