angular - 使用 zone.js 0.9.1 时,更改检测在 Electron 应用程序中停止工作
问题描述
我更新了一个我最近从 Angular 6 继承到 Angular 8 的 Electron 应用程序。使用 zone.js 0.9.1(更新:根本原因是这个版本的 zonejs 中的错误 - 请参阅下面的自我回答)
遵循升级指南等,一切都在编译和运行——直到我开始触发更新模型的操作并注意到视图没有立即更新。我注意到的行为是,如果我执行诸如单击选项卡或打开对话框或单击按钮之类的操作,则在单击其他内容之前视图不会更新。
我意识到这是某种变化检测或区域问题,但其他一切正常。但无论出于何种原因,该区域无法识别模型更改,因此视图不会刷新,直到另一个动作(如单击)触发它。
在 Angular 之外进行更改后,我有一些处理更新视图的经验,因此我尝试在区域承诺中包装几个事件处理程序,如下所示:
this.zone.run(() => ...do the stuff it was doing before... )
它起作用了——在重新编译应用程序后,我现在看到按钮单击和对话框打开时视图立即更新,就像它在 Angular 6 中所做的那样。
但是后来我发现很多我没有自己的处理程序的更改也不起作用,例如更改内部的选项卡mat-tab-group
和默认对话框按钮。
所以这变成了一个兔子洞——我可能会为每个选项卡单击和按钮单击实现自定义事件处理程序,但这似乎是一个巨大且不必要的痛苦,特别是考虑到我没有对应用程序逻辑本身进行任何更改,只是升级到 Angular 8。我可能忘记了一些东西或有一个奇怪/特殊情况,因为它是一个电子应用程序(我最近使用相同的将网络应用程序从 Angular 6 转换为 8 时没有遇到这些问题过程)。
我难住了。希望社区可以指出我的问题和解决方案——如果一切都失败了,我想我会编写大量的自定义处理程序并将每一行代码包装进去this.zone.run(()=>...)
——谢谢!
解决方案
因为我已经修复了许多与 Angular 2 版本跳转相关的问题,所以我忽略了一个控制台错误(“无法读取未定义的属性 'eventNames'”),起初我认为这是无关的,但是,呃,注意到 zone。 js 在堆栈中。
做了更多研究,发现这是 zone.js 版本 0.9.1 和 Electron 的一个已知问题(请参阅https://github.com/angular/angular/issues/31626)
我只使用那个版本是因为一个并行项目(非 Electron)运行良好并且在 0.9.1 上,所以我觉得出于某种原因让它们保持同步,但是在更新到 0.10.2 后eventNames
错误消失了,并且变化检测正常工作。这完全是由于一些存根函数返回undefined
而不是带有eventNames
.
谢谢阅读; 更新到最新的工作,幸运的是这个问题在几周前得到了解决。
推荐阅读
- json - 如何在 React 中导入 json 文件
- scala - 如何访问在spark scala中的catch块中尝试catch块之前声明的变量
- php - PHP子字符串在某个字符后删除字符串中的所有内容
- javascript - WordPress 错误:即使在 JS 文件入队后,$(...).carousel 也不是函数
- r - r:链接 Plotly 动画视图
- html - 无法让图像出现在背景前面
- php - 使用 phpmailer 显示 json_encode 警报时出错
- python - 如何计算Python列表中特定列表的出现次数
- windows - 如何使用 PowerShell 获取已安装 Windows 程序的逗号分隔表?
- c++ - 如何转换 boost::fusion::vector 的类型?