<input type="file">
表单的enctype必须指定为multipart/form-data,method必须指定为post
文件扩展名检查
<form method="post" action="http://localhost/test" enctype="multipart/form-data">
<p>
<input type="file" id="test-file-upload" name="test">
</p>
</form>
写在上面代码后面
var f=document.getElementById('test-file-upload');
f.addEventListener('change',function () {
var filename=f.value;
if(!filename||!(filename.endsWith('.jpg')||filename.endsWith('.png')||filename.endsWith('.gif'))){
alert('Çan only upload image file.');
return false;
}
});
File API (HTML5)
新增的File API允许JavaScript读取文件内容,获得更多的文件信息
两个主要对象 File和FileReader
<form method="post" action="http://localhost/test" enctype="multipart/form-data">
<p>图片预览:</p>
<p><div id="test-image-preview" style="border: 1px solid #ccc; width: 100%; height: 200px; background-size: contain; background-repeat: no-repeat; background-position: center center;"></div></p>
<p>
<input type="file" id="test-image-file" name="test">
</p>
<p id="test-file-info"></p>
</form>
var
fileInput = document.getElementById('test-image-file'),
info = document.getElementById('test-file-info'),
preview = document.getElementById('test-image-preview');
// 监听change事件:
fileInput.addEventListener('change', function () {
// 清除背景图片:
preview.style.backgroundImage = '';
// 检查文件是否选择:
if (!fileInput.value) {
info.innerHTML = '没有选择文件';
return;
}
// 获取File引用:
var file = fileInput.files[0];
// 获取File信息:
info.innerHTML = '文件: ' + file.name + '<br>' +
'大小: ' + file.size + '<br>' +
'修改: ' + file.lastModifiedDate;
if (file.type !== 'image/jpeg' && file.type !== 'image/png' && file.type !== 'image/gif') {
alert('不是有效的图片文件!');
return;
}
// 读取文件:
var reader = new FileReader();
reader.onload = function(e) {
var
data = e.target.result; // 'data:image/jpeg;base64,/9j/4AAQSk...(base64编码)...'
preview.style.backgroundImage = 'url(' + data + ')';
};
// 以DataURL的形式读取文件:
reader.readAsDataURL(file);
});
回调
JavaScript中,浏览器的JavaScript执行引擎在执行JavaScript代码时,总是以单线程模式执行,也就是说,任何时候,JavaScript代码都不可能同时有多于1个线程在执行。
在JavaScript中,执行多任务实际上都是异步调用 如
reader.readAsDataURL(file);
回调函数
reader.onload = function(e) {
// 当文件读取完成后,自动调用此函数:
};