问题描述
我正在尝试创建文件拖放上传。我已经使用 Angular 指令中的 HostListener 创建了带有 dragenter、dragleave 和 drop 事件的 div 容器。 dragenter 和 dragleave 事件正在工作,但在 drop 事件中 event.preventDefault() 不起作用。我的事件代码:
@HostListener('drop',['$event']) onDrop = (event): void => {
event.preventDefault();
}
我还尝试在 HTML DOM 中添加带有 (drop)="function($event)"
的事件,但这也不起作用。
解决方法
来自MDN website:
Event 接口的 preventDefault()
方法告诉用户代理,如果事件没有得到显式处理,则不应像通常那样采取其默认操作。 事件继续像往常一样传播,除非它的事件侦听器之一调用 stopPropagation()
或 stopImmediatePropagation()
,其中任何一个立即终止传播。
所以请尝试使用 event.stopPropagation()
或 event.stopImmediatePropagation()
。