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内部的服务,它只能在组件的上下文中使用。

相关内容

热门资讯

黑科技脚本(wopoker)正... 黑科技脚本(wopoker)正规吗(黑科技)有透视挂(一贯有挂)是一款可以让一直输的玩家,快速成为一...
黑科技辅助(微扑克ai辅助工具... 黑科技辅助(微扑克ai辅助工具)外挂透视辅助助手(透视)都是存在有挂(黑科技攻略)黑科技辅助(微扑克...
透视科技(wpK)透视外挂(黑... 一、简介了解软件请加微:136704302是一款在线扑克游戏平台,玩家可以在平台上进行多人在线扑克游...
黑科技挂(wePoKe)辅助挂... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
黑科技游戏(德州之星辅助器多少... 黑科技游戏(德州之星辅助器多少钱)外挂透视辅助插件(透视)切实有挂(黑科技细节);在进入德州之星辅助...
黑科技总结(wePoKe)软件... 黑科技总结(wePoKe)软件免费版(黑科技)软件透明演示(原来真的是有挂);无聊就玩这款真的有辅助...
黑科技辅助(wepoke是机器... 黑科技辅助(wepoke是机器发牌吗)外挂透明挂辅助技巧(透视)一贯真的有挂(黑科技揭秘)黑科技辅助...
普及辅助(微扑克)辅助提高胜率... 普及辅助(微扑克)辅助提高胜率(辅助挂)德州外挂(总是真的是有挂)1、不需要AI权限,帮助你快速的进...
黑科技脚本(wepokeai机... 黑科技脚本(wepokeai机器人)外挂透明挂辅助安装(透视)都是是有挂(黑科技黑科技)1、该软件可...
科普辅助(微扑克)ai机器人(... 科普辅助(微扑克)ai机器人(辅助挂)职业代打(原来真的有挂)是一款可以让一直输的玩家,快速成为一个...