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()包装执行函数,在浏览器环境下运行该函数。这样既可以解决问题,也可以保证性能。

相关内容

热门资讯

透视插件!hhpoker可以控... 透视插件!hhpoker可以控制吗(透视)一直是有挂(详细辅助wpk教程)1、构建自己的辅助插件;2...
玩家必看科普!wepoker透... 1、玩家必看科普!wepoker透视脚本免费,hhpoker外挂靠谱吗,大神讲解(有挂攻略)。2、w...
专业讨论!aapoker发牌逻... 专业讨论!aapoker发牌逻辑,哈糖大菠萝软件下载,解密教程(有挂技巧);1.哈糖大菠萝软件下载 ...
透视透视!德普之星辅助工具如何... 透视透视!德普之星辅助工具如何设置(透视)总是真的是有挂(详细辅助可靠教程)1、机器人多个强度级别选...
最新通报!wepoker透视脚... 最新通报!wepoker透视脚本免费下载pc,wepoker透视器免费,解密教程(有挂技巧)1、不需...
透视透视!wepoker永久免... 透视透视!wepoker永久免费脚本(透视)都是真的是有挂(详细辅助必赢教程)1、完成的残局,帮助玩...
实测发现!wejoker辅助器... 1、实测发现!wejoker辅助器要钱玩吗,红龙poker作弊指令,AA德州教程(有挂方法);详细教...
透视规律!hhpoker破解工... 透视规律!hhpoker破解工具(透视)本来是有挂(详细辅助可靠教程)亲,关键说明,赛季回归,软件透...
盘点一款!wepoker轻量版... 盘点一款!wepoker轻量版透视方法,wepoker透视脚本免费,黑科技教程(有挂神器)是一款可以...
透视黑科技!德扑圈透视挂(透视... 透视黑科技!德扑圈透视挂(透视)好像有挂(详细辅助扑克教程)辅助器中分为三种模型:软件透明挂、辅助挂...