gpt4 book ai didi

javascript - input[type ="file"] 确定用户是否未选择任何文件

转载 作者:行者123 更新时间:2023-12-01 00:37:52 32 4
gpt4 key购买 nike

当用户单击输入[type="file"]时,它会显示一个弹出窗口以选择文件

用户可以选择一个并单击“确定”或单击“取消”

当他们单击“确定”时 - 这是 onChange 事件,太棒了

取消时 - 没有事件或我不知道

所以问题是:

当用户单击“取消”时会触发什么事件,或者如何以不同的方式确定单击“取消”后没有选择任何文件?

最佳答案

当用户通过单击文件输入启动文件上传时,您可以向浏览器窗口添加事件监听器以查看它何时重新获得焦点。由于系统对话框是阻塞/模态的,因此只有当对话框关闭时窗 Eloquent 会重新获得焦点。

在事件处理函数中,您可以检查输入的值是否发生变化。最后,删除焦点事件处理程序,这样它就不会从正常的 alt-tab 或窗口焦点事件中触发:

file.addEventListener("click", function () {
window.onfocus = function () {
console.log("The window was re-focused from the file input dialog");

if (file.files.length === 0) {
console.log("NO files were added");
} else {
console.log("Files were added");
}

// Remove the handler
window.onfocus = null;
};
});
<input id="file" type="file">

关于javascript - input[type ="file"] 确定用户是否未选择任何文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57946703/

32 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com