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

相关内容

热门资讯

此事迅速冲上热搜!微乐小程序免... 此事迅速冲上热搜!微乐小程序免费黑科技,2025微乐小程序黑科技(透视)一贯真的是有挂(哔哩哔哩)1...
第一分钟下载!微乐小程序黑科技... 第一分钟下载!微乐小程序黑科技,微乐微信小程序辅助软件(开挂)总是真的是有挂(2026)1、全新机制...
透视教学!微乐小程序免费黑科技... 透视教学!微乐小程序免费黑科技,微乐锄大地脚本(透视)其实是真的挂(哔哩哔哩)1)微乐小程序免费黑科...
3分钟透视!微乐小程序免费黑科... 3分钟透视!微乐小程序免费黑科技,微乐贵阳捉鸡麻将辅助(开挂)总是真的有挂(2026)微乐小程序免费...
值得注意的是!微乐小程序免费黑... 值得注意的是!微乐小程序免费黑科技,微乐小程序挂哪里有(透视)其实有挂(哔哩哔哩)1、每一步都需要思...
第7分钟辅助!微乐小程序免费黑... 第7分钟辅助!微乐小程序免费黑科技,微乐广西小程序插件(开挂)总是真的有挂(2026)微乐小程序免费...
透视安卓版!微乐小程序免费黑科... 透视安卓版!微乐小程序免费黑科技,微乐自建房脚本免费下载入口(透视)切实是真的挂(哔哩哔哩)一、微乐...
第9分钟神器!微乐小程序免费黑... 第9分钟神器!微乐小程序免费黑科技,微乐小程序授权(开挂)总是存在有挂(2026)微乐小程序免费黑科...
一分钟开挂!微乐小程序黑科技,... 一分钟开挂!微乐小程序黑科技,微信小程序微乐游戏修改器(开挂)都是存在有挂(2026)1、微乐小程序...
代打辅助挂!微乐小程序黑科技,... 代打辅助挂!微乐小程序黑科技,微乐小程序辅助工具(透视)切实真的是有挂(哔哩哔哩)1、实时微乐小程序...