How to remove one specific selected file from input file control?
I have an input file control with the option to select multiple files; however, I want to validate a file and if it has an wrong extension then I should remove that file from the file control itself, is it possible?
I tried as below
<input type="file" name="fileToUpload" id="fileToUpload" multiple/>
<script> $("#fileToUpload")[0].files[0] </script>
Below is the screenshot of the object but I am not able to modify it
html
javascript
As other people pointed out,
FileList
is read only. You can get around this by pushing those files into a separateArray
though. You can then do whatever you want with that curated list of files. If uploading them to a server is the goal, you can use theFileReader
API.Below is a round about way of completely avoiding needing to modify the
FileList
. Steps:FileReader
API to read files locallyEvent handler and basic file loop code:
Below is a more complicated version of the file loop that shows how you can use the
FileReader
API to load the file into the browser and optionally submit it to a server as a Base64 encoded blob.A note of caution about using
FileReader
API. Base64 encoding a file will increase its size by around 30%. If that isn't acceptable you will need to try something else.I thought that I should add my comment here as well here (I've answered here: JavaScript delete File from FileList to be uploaded)
I found a workaround. This will not require AJAX for the request at all and the form can be sent to the server. Basically you could create an
hidden
ortext
input and set it'svalue
attribute to the base64 string created after processing the file selected.You will probably consider the idea to create multiple input file instead of input
text
orhidden
. This will not work as we can't assign a value to it.This method will include the input file in the data sent to the database and to ignore the input file you could:
disabled
attribute to the input file before serialising the form;When you want to delete a file just get the index of the element and remove the input element (text or hidden) from the DOM.
Requirements:
change
event.Pros: