AngularUniversalWindow.addEventListener不是函数问题
创始人
2024-10-29 21:01:21
0

问题的原因是Angular Universal使用了node.js和server-side rendering(服务器端渲染),而addEventListener()是浏览器中的函数,不适用于node.js环境下的服务器端渲染。因此可采用以下方式修改代码:

  • 方法一:在使用addEventListener()之前判断是否存在window对象(即是否在浏览器环境),若存在则执行该函数
if (typeof window !== 'undefined') {
  window.addEventListener('scroll', () => {
    // 执行操作
  });
}
  • 方法二:使用ngZone来包装该函数的执行,让其在浏览器环境下运行
import { Component, NgZone, OnInit } from '@angular/core';

@Component({
  selector: 'app-example',
  templateUrl: './example.component.html',
  styleUrls: ['./example.component.css']
})
export class ExampleComponent implements OnInit {

  constructor(private ngZone: NgZone) { }

  ngOnInit(): void {
    if (typeof window !== 'undefined') {
      this.ngZone.runOutsideAngular(() => {
        window.addEventListener('scroll', () => {
          // 执行操作
        });
      });
    }
  }

}

使用ngZone时,首先需导入NgZone模块,然后在构造函数中注入。其次,用ngZone.runOutsideAngular()包装执行函数,在浏览器环境下运行该函数。这样既可以解决问题,也可以保证性能。

相关内容

热门资讯

透视辅助!wpk私人局辅助是真... 透视辅助!wpk私人局辅助是真的吗,wepoker辅助器官方(透视)有挂教程(存在有挂)-哔哩哔哩所...
透视免费!wepoker破解版... 透视免费!wepoker破解版内购,hhpoker到底可以辅助码(透视)专业教程(有挂方针)-哔哩哔...
透视科技!拱趴大菠萝万能挂图解... 透视科技!拱趴大菠萝万能挂图解,hhpoker怎么开透视(透视)分享教程(真实有挂)-哔哩哔哩1)拱...
透视透视挂!拱趴大菠萝辅助神器... 透视透视挂!拱趴大菠萝辅助神器,红龙poker有辅助吗(透视)必备教程(有挂功能)-哔哩哔哩1、完成...
透视能赢!德普之星辅助工具如何... 透视能赢!德普之星辅助工具如何设置,约局吧是否有挂(透视)必备教程(有挂教学)-哔哩哔哩1)德普之星...
刚刚!wepoker辅助器软件... 刚刚!wepoker辅助器软件下载,wepoker私人局怎么玩(透视)解密教程(有挂规律)-哔哩哔哩...
受玩家影响!佛手在线大菠萝为什... 受玩家影响!佛手在线大菠萝为什么都输,pokemmo免费脚本(透视)总结教程(有挂透明挂)-哔哩哔哩...
透视好牌!wepoker祈福有... 透视好牌!wepoker祈福有用吗,wepoker公共底牌(透视)辅助教程(确实有挂)-哔哩哔哩1、...
出现新变化!hhpoker到底... 出现新变化!hhpoker到底可以辅助码,hhpoker为什么一直输(透视)揭幕教程(真是有挂)-哔...
透视教程!德普之星透视辅助,s... 透视教程!德普之星透视辅助,sohoopoker辅助(透视)揭露教程(讲解有挂)-哔哩哔哩1)德普之...