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

<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) {
    // 当文件读取完成后,自动调用此函数:
};
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • JavaScript 快速入门 浏览器浏览器对象操作 DOM插入 DOM删除 DOM 操作表单获取值设置值HTML...
    染微言阅读 5,613评论 0 5
  • 你走的第九十八天,还有15天。 想你想你想你想你,我做梦了都是噩梦,都怪洪雨蝶天天吓唬我,没事就从我身后出来吓我一...
    rainll阅读 1,118评论 0 1
  • 爱情有时候就是这样。想不到的意外总是再发生。你在等待你的爱情从新回到你身边。但是却出乎你的意料,心里想的却跟现实有...
    鬼精阅读 2,338评论 0 0
  • 今天亲子阅读的是.神奇校车的海底探险!前半部分她说她明白了原来海洋里大部分盐和我们放在食物里的盐是一样的!知道了沙...
    谭钰涵阅读 2,755评论 0 0
  • 坦白说,我对自己参加这次初级班和武林计划很不满意。相比思维导图武林计划的作业完成度和跟课程度,真是觉得惭愧。 刚开...
    艺文Aurora阅读 1,930评论 2 2