您的位置:首页 > Web前端 > HTML5

HTML5学习之FileReader new FormData()

2016-06-02 18:30 316 查看
文章来源:http://blog.csdn.net/zk437092645/article/details/8745647
H5 new FormData()上传图片:http://www.cnblogs.com/lhb25/p/html5-formdata-tutorials.html
效果查看这里:http://runjs.cn/code/oatvq0ro

用来把文件读入内存,并且读取文件中的数据。FileReader接口提供了一个异步API,使用该API可以在浏览器主线程中异步访问文件系统,读取文件中的数据。到目前文职,只有FF3.6+和Chrome6.0+实现了FileReader接口。

1、FileReader接口的方法

FileReader接口有4个方法,其中3个用来读取文件,另一个用来中断读取。无论读取成功或失败,方法并不会返回读取结果,这一结果存储在result属性中。

FileReader接口的方法
方法名 参数描述
readAsBinaryStringfile将文件读取为二进制编码
readAsTextfile,[encoding]将文件读取为文本
readAsDataURLfile将文件读取为DataURL
abort(none)终端读取操作
2、FileReader接口事件

FileReader接口包含了一套完整的事件模型,用于捕获读取文件时的状态。

FileReader接口的事件
事件描述
onabort中断
onerror出错
onloadstart开始
onprogress正在读取
onload成功读取
onloadend读取完成,无论成功失败
3、FileReader接口的使用

[html] view
plain copy

<script type="text/javascript">  

var result=document.getElementById("result");  

var file=document.getElementById("file");  

  

//判断浏览器是否支持FileReader接口  

if(typeof FileReader == 'undefined'){  

    result.InnerHTML="<p>你的浏览器不支持FileReader接口!</p>";  

    //使选择控件不可操作  

    file.setAttribute("disabled","disabled");  

}  

  

function readAsDataURL(){  

    //检验是否为图像文件  

    var file = document.getElementById("file").files[0];  

    if(!/image\/\w+/.test(file.type)){  

        alert("看清楚,这个需要图片!");  

        return false;  

    }  

    var reader = new FileReader();  

    //将文件以Data URL形式读入页面  

    reader.readAsDataURL(file);  

    reader.onload=function(e){  

        var result=document.getElementById("result");  

        //显示文件  

        result.innerHTML='<img src="' + this.result +'" alt="" />';  

    }  

}  

  

function readAsBinaryString(){  

    var file = document.getElementById("file").files[0];  

    var reader = new FileReader();  

    //将文件以二进制形式读入页面  

    reader.readAsBinaryString(file);  

    reader.onload=function(f){  

        var result=document.getElementById("result");  

        //显示文件  

        result.innerHTML=this.result;  

    }  

}  

  

function readAsText(){  

    var file = document.getElementById("file").files[0];  

    var reader = new FileReader();  

    //将文件以文本形式读入页面  

    reader.readAsText(file);  

    reader.onload=function(f){  

        var result=document.getElementById("result");  

        //显示文件  

        result.innerHTML=this.result;  

    }  

}  

</script>  

<p>  

    <label>请选择一个文件:</label>  

    <input type="file" id="file" />  

    <input type="button" value="读取图像" onclick="readAsDataURL()" />  

    <input type="button" value="读取二进制数据" onclick="readAsBinaryString()" />  

    <input type="button" value="读取文本文件" onclick="readAsText()" />  

</p>  

<div id="result" name="result"></div>  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: