Angular在promise内部的发射不起作用
创始人
2024-10-30 20:30:50
0

问题描述: 在Angular中,当在Promise内部尝试发射事件时,事件似乎无法被触发。

解决方法: 要在Angular中的Promise内部发射事件,需要使用Angular的ChangeDetectorRef服务来手动触发变更检测。

以下是解决方法的代码示例:

import { Component, OnInit, ChangeDetectorRef } from '@angular/core';

@Component({
  selector: 'app-my-component',
  template: `
    
    
{{ result }}
` }) export class MyComponent implements OnInit { result: string; constructor(private cdRef: ChangeDetectorRef) {} ngOnInit() {} startAsyncTask() { this.result = 'Task started'; // 模拟异步任务 const promise = new Promise((resolve, reject) => { setTimeout(() => { this.result = 'Task completed'; // 手动触发变更检测 this.cdRef.detectChanges(); resolve(); }, 2000); }); // 可选:可以在任务完成后执行一些额外的逻辑 promise.then(() => { console.log('Task finished'); }); } }

在上面的代码中,我们使用了ChangeDetectorRef服务来手动触发变更检测。在Promise的resolve回调中,我们调用了this.cdRef.detectChanges()来通知Angular检查组件的变更。这将触发组件的重新渲染,并更新模板中的绑定。

请注意,ChangeDetectorRef服务必须在组件的构造函数中注入,并且不能在构造函数外部使用。这是因为ChangeDetectorRef是Angular内部的服务,它只能在组件的上下文中使用。

相关内容

热门资讯

透视教程书!hhpoker外g... 透视教程书!hhpoker外g挂靠谱吗,HHpoker透视器切实真的有工具,九分钟教程(真实有挂)1...
透视技法!德普之星透视软件免费... 透视技法!德普之星透视软件免费入口官网,德普之星下载原来存在有开挂,第九分钟教程(真的有挂)1、全新...
透视方案!德普之星透视辅助软件... 透视方案!德普之星透视辅助软件是真的吗,德普之星安卓版总是真的是有神器,四分钟教程(果真有挂)1.德...
透视经验!wpk透视辅助方法,... 透视经验!wpk透视辅助方法,WPK靠谱总是真的是有神器,第7分钟教程(有挂分享)1、许多玩家不知道...
透视绝活儿!pokemmo脚本... 透视绝活儿!pokemmo脚本手机版,WePoKer助手确实存在有透视,十分钟教程(真是有挂)1、p...
透视手段!德扑圈透视挂,德扑之... 透视手段!德扑圈透视挂,德扑之心透视好像存在有下载,1分钟教程(揭秘有挂)1、全新机制【德扑圈透视挂...
透视法门!黑侠破解wepoke... 透视法门!黑侠破解wepoker,WePoKer程序一直真的有工具,第二分钟教程(有挂透明挂)所有人...
透视妙招!德州局HHpoker... 透视妙招!德州局HHpoker透视脚本,HHpoker德州局总是是有下载,九分钟教程(了解有挂)亲,...
透视要领!hhpoker是正规... 透视要领!hhpoker是正规的吗,HHpoker脚本挂原来真的有安装,十分钟教程(有挂功能)1、玩...
透视攻略!xpoker辅助器,... 透视攻略!xpoker辅助器,WePoKer亲友圈都是真的有教程,四分钟教程(有挂规律)该软件可以轻...