【发布时间】:2021-04-07 08:22:53
【问题描述】:
我正在尝试创建文件拖放上传。我已经使用 Angular 指令中的 HostListener 创建了带有 dragenter、dragleave 和 drop 事件的 div 容器。 dragenter 和 dragleave 事件正在工作,但在 drop 事件中 event.preventDefault() 不起作用。我的活动代码:
@HostListener('drop', ['$event']) onDrop = (event): void => {
event.preventDefault();
}
我还尝试在 HTML DOM 中添加带有 (drop)="function($event)" 的事件,但这也不起作用。
【问题讨论】:
-
发生了什么不应该发生的事情?你确定
preventDefault会阻止这种行为吗?可能有另一个事件触发了drop。 -
抱歉忘了告诉。当我使用事件在 div 容器上拖动图像时,它将在我的浏览器中打开图像(在 chrome 中它会打开一个新选项卡,在 Firefox 中它会在同一个选项卡中打开),或者当我拖动任何其他不受支持的文件格式时通过浏览器它会下载它。至少我知道,没有其他事件可以阻止它。我刚刚创建了那个角度组件,没有其他东西可以阻止它。
-
这个问题可能对你有帮助:stackoverflow.com/questions/35274028/…
-
谢谢,但这也无济于事 :( 但该事件肯定会触发,我已经在“文件”类型的输入上对其进行了测试。但在 div 本身上它仍然打开图片在我的浏览器中:/
-
我创建了一个新的 Angular 项目,删除了 app.component.html 中的所有内容,创建了一个 div
<div id="dropZone" (drop)="dropZoneEvent($event)"></div>和代码dropZoneEvent($event: DragEvent) {$event.preventDefault(); }以及一些用于背景颜色和大小的 css。 .仍然没有工作......我做错了什么??? :(
标签: angular typescript events preventdefault angular11