如何解决从另一个函数访问 ngOnInit 的本地变量
我是 Angular 和 TS 的新手。我试图从外部访问 ngOnInit 中的本地变量,但我不知道如何正确执行。我有一个名为 BlocklyComponent 的组件,我在其中创建了 var。
export class BlocklyComponent implements OnInit {
primaryWorkspace: Blockly.WorkspaceSvg;
constructor(private sanitizer: DomSanitizer) {
this.updateXML = this.updateXML.bind(this);
}
ngOnInit() {
var primaryWorkspace = Blockly.inject('primaryDiv',{....} as Blockly.BlocklyOptions);
在 NgOnInit 函数内部它工作正常,我可以毫无问题地看到对象。但是,当我添加 addchangelistener 以在发生事件时读取时,我无法从 ngOnInit 外部的新函数访问该本地变量。
primaryWorkspace.addchangelistener(this.updateXML); //addchangelistener is special for Blockly library
}
updateXML(primaryEvent )
{
if (primaryEvent.isUiEvent)
{
return; //Do not clone ui events
};
var xml = Blockly.Xml.workspacetoDom(primaryWorkspace); //XML machine. Blockly is a library.
console.log(xml);
}
我试图将这个 (this.primaryWorkspace) 添加到调用中,但它采用的是属性而不是本地变量。我知道可以在 ngOnInit 内部创建函数并且它可以工作,但我需要在外部创建 updateXML。 非常感谢
解决方法
最后,这是一个简单的问题。我通过将 var 声明为 this.primaryWorkspace 而不是将其声明为 VAR 自己解决了这个问题。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。