我的意思是,当用户从他们的系统中选择视频文件时,让网页已经向他们显示他们想要上传的文件。
我已经在使用 FileAPI JS 使用图像文件进行预览。我想对视频文件的 FileAPI JS 做同样的事情。
(所以,它必须在我的客户端工作)
感谢和回答表示赞赏:)
我的意思是,当用户从他们的系统中选择视频文件时,让网页已经向他们显示他们想要上传的文件。
我已经在使用 FileAPI JS 使用图像文件进行预览。我想对视频文件的 FileAPI JS 做同样的事情。
(所以,它必须在我的客户端工作)
感谢和回答表示赞赏:)
您可以使用FileReader或createObjectURL。他们都会完成工作,但 FileReader 在浏览器中的支持稍微广泛一些。
createObjectURL
将同步运行并返回一个 Blob URL,一个引用内存中文件的短字符串。并且您可以在使用完后立即释放它。
FileReader
将异步运行,需要一个回调,提供一个数据 URI,一个代表整个文件的更长的字符串。这可能非常大,并且会在 Javascript 垃圾收集中从内存中释放出来。
这是一个首先尝试createObjectURL
并回退到FileReader
. (请提供您自己的错误检查等)
var video = document.getElementById('video'),
input = document.getElementById('input');
input.addEventListener('change', function (evt) {
var reader = new window.FileReader(),
file = evt.target.files[0],
url;
reader = window.URL || window.webKitURL;
if (reader && reader.createObjectURL) {
url = reader.createObjectURL(file);
video.src = url;
reader.revokeObjectURL(url); //free up memory
return;
}
if (!window.FileReader) {
console.log('Sorry, not so much');
return;
}
reader = new window.FileReader();
reader.onload = function(evt) {
video.src = evt.target.result;
};
reader.readAsDataURL(file);
}, false);
这里的工作示例:http: //jsbin.com/isodes/1/edit
Mozilla 有一篇更详细的文章,其中包含有关如何在获得文件后上传的说明。
IE10 两者都支持,但 IE9 都不支持,因此您必须退回到没有预览的常规表单上传。