I am working with a standard file input for uploads, and I am looking for a way to attach a function to an event when the user clicks/hits enter on the "cancel" button (or escapes out from) the choose file dialog.
I can't find any events that work across all browsers and platforms consistently.
I've read the answers to this question: Capturing cancel event on input type=file but they don't work, as the change event doesn't fire in most browsers on canceling out of the choose file dialog.
I'm looking for a pure js solution, but open to jquery solutions as well.
Anyone solve this problem successfully?
I had the problem where I clicked the cancel button on the input type="file" element and wanted the function to do nothing. if something was selected and I clicked the open button then I wanted my function to do something. The example only shows the method, I stripped out what I do with it after it opens. I put in the alerts just so you could see there isn't a filename coming back from the dialog when cancel is clicked. Here is a method I use, it is simple but it works.
A bit of research indicates that there is no way to detect when Cancel is selected in the File Selection dialog window. You can use
onchange
oronblur
to check if files have been selected or if something has been added to the inputvalue
.This could look like: https://jsfiddle.net/Twisty/j18td9cs/
HTML
JavaScript
I suggest making your own cancel or reset button that resets the form or clears the value from the input.