w3c / FileAPI

File API
https://w3c.github.io/FileAPI/
Other
104 stars 44 forks source link

Add FileList constructor #24

Open dmoagx opened 8 years ago

dmoagx commented 8 years ago

Split out from https://www.w3.org/Bugs/Public/show_bug.cgi?id=17125 :

The

<input type="file" name="something" />

element has always been readonly (you can't change value) for security purposes. That makes sense as a string could always be manipulated by JS.

The File object on the other hand should be "safe", as in

So it should not be a security issue to allow assignment to a file input. For example:

<input type="file" name="something[]" onchange="splitFiles();" id="in1" multiple="multiple" />
function splitFiles() {
  var in = document.getElementById('in1');
  //create single inputs
  for(var i=0;i<in.files.length;i++) {
        var newEl = document.createElement('input');
        newEl.name = "something[]";
        newEl.id = '...';
        newEl.type = "file";
        newEl.value = in.files[i]; // <-- assignment of file object
        document.appendChild(newEl); //add for upload
        //create some UI to remove this input
        //...
    }
    //remove the multi-input
    in.parent.removeChild(in);
}

This code would split a multi-file-input back to multiple single-file inputs (that way applications with a legacy backend that only supports the classical way could also support multi-file-inputs).

Another use would be with File objects obtained by drag and drop. Right now those require XHR to upload. Allowing to make them a selection of a file input could simplify some situations as well as provide richer UI (when showing a traditional file input together with a drop area those would stay in sync).

vsesh commented 7 years ago

19

inexorabletash commented 6 years ago

I think we can close this c/o https://github.com/whatwg/html/issues/2861 being resolved?

annevk commented 6 years ago

The first use case for legacy backends can't be done until https://github.com/whatwg/html/issues/3269 is resolved somehow. We could use this as the File API side issue for that, as it'll need to change here eventually.