Angular 11+自定义指令中调用scroll无效

发布于 2022-09-12 14:00:02 字数 1454 浏览 25 评论 0

导航条(Nav)在连接过多时,一部分会被隐藏掉,希望在激活指定的连接时,激活的连接会显示出来.通过调用:Nav.scroll(x,0)来进行横向移动。现在只有在FireFox中正常,Webkit内核的浏览器scoll无效

  constructor(private elementRef: ElementRef, private renderer2: Renderer2) { }
  ngOnInit(): void {
    console.log('screen width:'+window.innerWidth);
    //小屏幕导航时选中的元素在当前屏幕中可见
    if(window.innerWidth < 767){
      let nav:HTMLElement =this.elementRef.nativeElement.querySelector('#nav-tab')as HTMLElement;
      if(!nav){
        console.log('[appStickyScrollNavbar] not find element:#nav-tab');
      }
      let focEle:Element = nav.querySelector('a.active') as Element;
      if(!focEle){
        console.log('[appStickyScrollNavbar] not find active element:a.active');
      }

      let ofLeft:number = focEle.getBoundingClientRect().left;
      let eleWidth:number = focEle.getBoundingClientRect().width;
      console.log('[appStickyScrollNavbar]find active element client rect left:'+ofLeft);
      console.log('[appStickyScrollNavbar]find active element width:'+eleWidth);
      //FireFox
      nav.scrollTo((ofLeft-eleWidth), 0);
    }
  }

隐藏的样式如下:

  .tabbable .nav-tabs {
    overflow-x: auto;
    overflow-y:hidden;
    flex-wrap: nowrap;
  }
  .tabbable .nav-tabs .nav-link {
    white-space: nowrap;
    margin:0;
    padding:0 0.5rem
  }
  .tabbable .nav-tabs .nav-link.active{
    border-bottom-color:#007bff;
    background-color:#f6f6f6;
    color:#007bff
  }

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

攀登最高峰 2022-09-19 14:00:02

换个生命周期函数呢,操作dom的操作,不知道在ngAfterViewInit中是否有效

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文