Angular中的@ViewChild或本地元素问题
创始人
2024-10-31 02:00:29
0

Angular中的@ViewChild装饰器用于查询子组件、指令或本地元素。当使用它们时,可能会遇到一些问题,特别是与本地元素有关的问题。

一个常见的@ViewChild问题是无法访问native element。通常情况下,我们可以使用ViewChild访问组件的本地元素,但是在某些情况下,我们需要访问本地元素的原生DOM元素。例如,在以下代码中,我们想访问焦点所在元素的scrollTop属性:

@Component({
  selector: 'app-example',
  template: `

Here is the content

` }) export class ExampleComponent { @ViewChild('divElement') divElement: ElementRef; onScroll() { console.log(this.divElement.nativeElement.scrollTop); } }

但是,这种方式可能会导致以下错误:TypeError: Cannot read property 'scrollTop' of undefined。

为了解决这个问题,我们需要使用投影注入(Projection Injection)。投影注入是Angular元素的实际DOM结构注入到模板中。在本地元素上使用projection注入指令将本地元素的实际DOM结构注入到模板中。然后,我们就可以在代码中使用原生指令来访问它们。

下面是改写后的代码:

@Component({
  selector: 'app-example',
  template: `

Here is the content

` }) export class ExampleComponent implements AfterViewInit { @ViewChild('divElement', {read: ElementRef}) divElementRef: ElementRef; ngAfterViewInit() { const divElement = this.divElementRef.nativeElement; divElement.addEventListener('scroll', () => { console.log(divElement.scrollTop); }); } }

在这个例子中,我们通过在本地元素上添加元素来使用投影注入。然后,我们在ViewChild装饰器中使用{read: ElementRef}选项来指定我们想要注入原生DOM元素。

在ngAfterViewInit生命周期钩子中,我们访问元素的nativeElement属性并添加滚动事件监听器。现在,我们可以访问原生DOM元素并查看scrollTop

相关内容

热门资讯

透视玄学!潮汕暗宝辅助透视&q... 透视玄学!潮汕暗宝辅助透视"有挂辅助方法"其实是真的有挂(哔哩哔哩)潮汕暗宝辅助透视脚本下载中分为三...
今天下午!填大坑辅助器&quo... 今天下午!填大坑辅助器"必备辅助攻略"一直确实有挂(哔哩哔哩)1、每一步都需要思考,不同水平的挑战填...
据悉!中至小程序如何破解&qu... 据悉!中至小程序如何破解"透视辅助工具"好像真的是有挂(哔哩哔哩)中至小程序如何破解脚本下载中分为三...
透视辅助!闲来游戏辅助软件&q... 透视辅助!闲来游戏辅助软件"专业辅助教程"好像真的有挂(哔哩哔哩)1、金币登录送、破产送、升级送、活...
透视透视!扣点点脚本辅助器&q... 透视透视!扣点点脚本辅助器"揭幕辅助方法"总是真的是有挂(哔哩哔哩)扣点点脚本辅助器脚本下载中分为三...
据了解!九游辅助器"... 据了解!九游辅助器"详细辅助工具"竟然存在有挂(哔哩哔哩)暗藏猫腻,小编详细说明九游辅助器破解器有用...
总结辅助挂!巴蜀长牌辅助&qu... 总结辅助挂!巴蜀长牌辅助"详细辅助器"原来是有挂(哔哩哔哩)1、巴蜀长牌辅助免费脚本咨询教程、巴蜀长...
目前!安卓闲逸辅助"... 目前!安卓闲逸辅助"专业辅助插件"果然确实有挂(哔哩哔哩)1、下载好安卓闲逸辅助脚本下载之后点击打开...
截至发稿!水鱼辅助软件下载&q... 截至发稿!水鱼辅助软件下载"揭露辅助攻略"竟然真的有挂(哔哩哔哩)1、进入到水鱼辅助软件下载是否有挂...
辅助透视!欢乐茶馆辅助器&qu... 辅助透视!欢乐茶馆辅助器"开挂辅助教程"都是真的有挂(哔哩哔哩)1、很好的工具软件,可以解锁游戏的欢...