[JavaScript基础]学习③④--操作文件

表单的enctype必须指定为multipart/form-data,method必须指定为post

文件扩展名检查

写在上面代码后面

 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

图片预览:

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 + '
' + '大小: ' + file.size + '
' + '修改: ' + 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) {
    // 当文件读取完成后,自动调用此函数:
};

你可能感兴趣的:([JavaScript基础]学习③④--操作文件)