我试图从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
答案 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);
}