首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >This.sanitizer是在NgOninit函数之外未定义的(角,TS)

This.sanitizer是在NgOninit函数之外未定义的(角,TS)
EN

Stack Overflow用户
提问于 2021-03-09 11:07:42
回答 1查看 167关注 0票数 0

首先,我将DomSanitizer导入到组件中:

代码语言:javascript
复制
import { DomSanitizer, SafeResourceUrl} from '@angular/platform-browser';

之后,我创建了一个类并将它添加到构造函数中:

代码语言:javascript
复制
 export class BlocklyComponent implements OnInit {
      primaryWorkspace: Blockly.WorkspaceSvg;
      GEE = "PCFET0NUWVBFIGh0bWw+Cgo8aGVhZD4KPG1ldGEgY29udGVudD0idGV4dC9odG1sOyBjaGFyc...";
    public geeMap: SafeResourceUrl;
      constructor(private sanitizer: DomSanitizer) {}
ngOnInit() {

但是,在NgOnInit函数内部,它正确地工作在updateURL函数中(在NgOnInit之外,但在类中),它说this.sanitizer是未定义的:

代码语言:javascript
复制
//Creates de src that has to be in the iframe. What I need to do is to update this safeResourceUrl.
        this.geeMap = this.sanitizer.bypassSecurityTrustResourceUrl(`data:text/html;base64,${this.GEE}`);

        //Reads the events in a workspace. When it notices a change, it triggers the updateURL function

        primaryWorkspace.addChangeListener(this.updateURL);

      }
      updateURL(primaryEvent) 
         {
          if (primaryEvent.isUiEvent) {
            return; //Do not clone ui events 
          };
          console.log('hola');
         //Problem. Here it sais that this.sanitizer is undefined.
          this.geeMap = this.sanitizer.bypassSecurityTrustResourceUrl(`data:text/html;base64,${this.GEE}`);
        }

我知道这是我经常遇到的一个典型问题,但是现在我不知道怎么解决了。我试图在不同的论坛寻找未知的问题,但我仍然无法解决它。非常感谢

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-03-09 11:14:46

由于要退出绑定事件的Angular流,可以通过两种方式添加事件侦听器,以处理正确的this :-

Arrow函数() :-**

primaryWorkspace.addChangeListener((event)=>this.updateURL(event));

.bind (inside constructor**) :-** )

this.updateURL = this.updateURL.bind(this);

ngOnInit中:-

primaryWorkspace.addChangeListener(this.updateURL);

另外,我认为你指的是addEventListener('change',...(而不是addChangeListener )。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66545750

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档