JS CustomEvent参数以Angular中未定义的方式传递

时间:2019-03-18 20:20:43

标签: javascript angular requestdispatcher

我试图从JS内调用Angular函数,但是传递给Angular的参数是不确定的。我想念什么?理想情况下,我也想从dispatchedEvent返回结果。我应该使用更好的解决方案吗?

JS函数

  var event = new CustomEvent('test', {
    id: "a", id2:"ttt"
  });
  window.dispatchEvent(event);

角度组件

  @HostListener('window:test', ['$event.id','$event.id2'])
  test(id,id2) {
    console.log('ang called from JS: '+id+' '+id2)
  }

输出到控制台:JS调用的ang:未定义未定义

目标:从JS调用的ang:一个ttt

1 个答案:

答案 0 :(得分:0)

据我所知,您只能将一个参数传递给CustomEvent,即detail。因此,您的代码不应编译。您需要将其更改为

onClick() {
  const event = new CustomEvent('test', {
    detail: {
      id: 'a', id2: 'ttt'
    }
  });
  window.dispatchEvent(event);
}

在此之后,您的处理程序将会

@HostListener('window:test', ['$event.detail.id', '$event.detail.id2'])
test(id, id2) {
  console.log('ang called from JS: ' + id + ' ' + id2);
}