FileReader和URL.createObjectURL(file)

FileReader

HTML5 定义了 FileReader 作为文件API的重要成员用于读取文件,根据W3C的定义,FileReader 接口提供了读取文件的方法和包含读取结果的事件模型。

FileReader的使用方式非常简单,可以按照如下步骤创建FileReader对象并调用其方法:

1. 检测浏览器对FileReader的支持 

if(window.FileReader) {
     var fileReader = new FileReader();
     // add your code here
 }
 else {
     alert("Not supported by your browser!");
 }

2. 调用FileReader对象的方法 

FileReader 的实例拥有 4 个方法,其中 3 个用以读取文件,另一个用来中断读取。下面的表格列出了这些方法以及他们的参数和功能,需要注意的是 ,无论读取成功或失败,方法并不会返回读取结果,这一结果存储在 result属性中。

方法名

参数

描述

abort

none

中断读取

readAsBinaryString

file

将文件读取为二进制码

readAsDataURL

file

将文件读取为 DataURL

readAsText

file, [encoding]

将文件读取为文本

3. FileReader处理事件简介

FileReader 包含了一套完整的事件模型,用于捕获读取文件时的状态,下面这个表格归纳了这些事件。

事件

描述

onabort

中断时触发

onerror

出错时触发

onload

文件读取成功完成时触发

onloadend

读取完成触发,无论成功或失败

onloadstart

读取开始时触发

onprogress

读取中

文件一旦开始读取,无论成功或失败,方法并不会返回读取结果,这一结果(储存在result属性中)要用FileReader处理事件去获取。

fileReader.onload = function() { 
    this.result; 
}; 

代码示例

1. readAsDataURL:上传图片并预览。

<script type="text/javascript">
    function uploadFile(){
            var file = document.getElementById("file").files[0];
            var reader = new FileReader();
            reader.readAsDataURL(file);
            reader.onload=function(e){
                document.getElementById("portrait").src = e.target.result;
            }
        }
</script>
 
<label>请选择一个文件:</label>
<input type="file" name="file" onchange="showPreview(this)" />
<img id="portrait" src="" width="70" height="75">

 如果要限定上传文件的类型,可以通过文件选择器获取文件对象并通过type属性来检查文件类型。

if(!/image\/\w+/.test(file.type)){
    alert("请确保文件为图像类型");
    return false;
}

2. 上传文件并回显文件内容

<script>
    function uploadFile(){
        var file = document.getElementById("file").files[0];
        var reader = new FileReader();
        reader.readAsText(file);
        reader.onload=function(e){
            document.getElementById("text").innerHTML = this.result;
        }
    }
</script>
<label>请选择一个文件:</label>
<input type="file" id="file" onchange="uploadFile()" multiple />
<div id="text">文件</div>

 

URL.createObjectURL(file)

URL.createObjectURL() 静态方法会创建一个 DOMString,其中包含一个表示参数中给出的对象的URL。这个 URL 的生命周期和创建它的窗口中的 document 绑定。这个新的URL 对象表示指定的 File 对象或 Blob 对象。

图片上传并预览。 

<script>
    function uploadFile(){
        var file = document.getElementById("file").files[0];
        // 图片预览
        document.getElementById("portrait").src = window.URL.createObjectURL(file);
    }
</script>
<label>请选择一个文件:</label>
<input type="file" id="file" onchange="uploadFile()" multiple />
<img id="portrait" src="" width="70" height="75">

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mephisto180502

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值