HTML5文件操作API

 
 
 

一、文件操作API


在之前我们操作本地文件都是使用flash、silverlight或者第三方的activeX插件等技术,由于使用了这些技术后就很难进行跨平台、或者跨浏览器、跨设备等情况下实现统一的表现,从另外一个角度来说就是让我们的web应用依赖了第三方的插件,而不是很独立。 在HTML5标准中,默认提供了操作文件的API让这一切直接标准化。有了操作文件的API,让我们的Web应用可以很轻松的通过JS来控制文件的读取、写入、文件夹、文件等一系列的操作。接下来主要给大家介绍文件读取的几个API。

二、几个重要的JS对象


1. FileList对象

它是File对象的一个集合,在HTML4标准中文件上传控件只接受一个文件,而在新标准中,只需要设置multiple,就支持多文件上传,所以从此标签中获取的files属性就是FileList对象实例。 demo:<input type="file" multiple="multiple" name="fileDemo" id="fileDemo" />; 下面是关于FileList对象的API的原型:

  1. interface FileList {
  2. getter File? item(unsigned long index);
  3. readonly attribute unsigned long length;
  4. };

2. Blob对象

其实就是一个原始数据对象,它提供了slice方法可以读取原始数据中的某块数据。另外有两个属性:size(数据的大小),type(数据的MIME类型; 看下面的是W3C的API原型:

  1. interface Blob {
  2. readonly attribute unsigned long long size;
  3. readonly attribute DOMString type;
  4. //slice Blob into byte-ranged chunks
  5. Blob slice(
  6. optional long long start,
  7. optional long long end,
  8. optional DOMString contentType
  9. );
  10. };

3. File对象

继承自Blob对象,指向一个具体的文件,它还有两个属性:name(文件名),lastModifiedDate(最后修改时间); W3C的标准:

  1. interface File : Blob {
  2. readonly attribute DOMString name;
  3. readonly attribute Date lastModifiedDate;
  4. };

4. FileReader对象

设计用来读取文件里面的数据,提供三个常用的读取文件数据的方法,另外读取文件数据使用了异步的方式,非常高效。 W3C的标准:

  1. [Constructor]
  2. interface FileReader: EventTarget {
  3. // async read methods
  4. void readAsArrayBuffer(Blob blob);
  5. void readAsBinaryString(Blob blob);
  6. void readAsText(Blob blob, optional DOMString encoding);
  7. void readAsDataURL(Blob blob);
  8. void abort();
  9. // states
  10. const unsigned short EMPTY = 0;
  11. const unsigned short LOADING = 1;
  12. const unsigned short DONE = 2;
  13. readonly attribute unsigned short readyState;
  14. // File or Blob data
  15. readonly attribute any result;
  16. readonly attribute DOMError error;
  17. // event handler attributes
  18. attribute [TreatNonCallableAsNull] Function? onloadstart;
  19. attribute [TreatNonCallableAsNull] Function? onprogress;
  20. attribute [TreatNonCallableAsNull] Function? onload;
  21. attribute [TreatNonCallableAsNull] Function? onabort;
  22. attribute [TreatNonCallableAsNull] Function? onerror;
  23. attribute [TreatNonCallableAsNull] Function? onloadend;
  24. };

这个对象是非常重要第一个对象,它提供了四个读取文件数据的方法,这些方法都是异步的方式读取数据,读取成功后就直接将结果放到属性result中。所以一般就是直接读取数据,然后监听此对象的onload事件,然后在事件里面读取result属性,再做后续处理。当然abort就是停止读取的方法。

FileReader对象的三个读取文件数据方法

  • readAsBinaryString(Blob blob) 传入一个Blob对象,然后读取数据的结果作为二进制字符串的形式放到FileReader的result属性中。
  • readAsText(Blob blob, optional DOMString encoding) 第一个参数传入Blog对象,然后第二个参数传入编码格式,异步将数据读取成功后放到result属性中,读取的内容是普通的文本字符串的形式。
  • readAsDataURL(Blob blob) 传入一个Blob对象,读取内容可以做为URL属性,也就是说可以将一个图片的结果指向给一个img的src属性。

三、读取文件上传控件里的文件并将内容已不同的方式展现到浏览器


在展示代码之前,之前我们操作一个图片文件,都是先将图片上传到服务器端,然后再使用一个img标签指向到服务器的url地址,然后再进行一个使用第三方插件进行图片处理,而现在这一切都不需要服务器端了,因为FileReader对象提供的几个读取文件的方法变得异常简单,而且全部是客户端js的操作。

实例一:获取上传文件的文件名(注:需要引入jQuery)

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <title></title>
  5. <script src="Scripts/jquery-1.5.1.js" type="text/javascript"></script>
  6. <script type="text/javascript">
  7. $(function () {
  8. $("#btnGetFile").click(function (e) {
  9. var fileList = document.getElementById("fileDemo").files;
  10. for (var i = 0; i < fileList.length; i++) {
  11. if (!(/image\/\w+/.test(fileList[i].type))) {
  12. $("#result").append("<span>type:"+fileList[i].type+"--******非图片类型*****--name:"+fileList[i].name+"--size:"+fileList[i].size+"</span><br />");
  13. }
  14. else {
  15. $("#result").append("<span>type:"+fileList[i].type+"--name:"+fileList[i].name+"--size:"+fileList[i].size+"</span><br />");
  16. }
  17. }
  18. });
  19. });
  20. </script>
  21. </head>
  22. <body>
  23. <form action="/home/index" method="POST" novalidate="true">
  24. <input type="file" multiple="multiple" name="fileDemo" id="fileDemo" /><br/>
  25. <input type="button" value="获取文件的名字" id="btnGetFile"/>
  26. <div id="result"></div>
  27. </form>
  28. <hr/>
  29. </body>
  30. </html>

实例二:读取上传文件内容,然后将文件内容直接读取到浏览器上(注:需要引入jQuery)

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <title></title>
  5. <script src="Scripts/jquery-1.5.1.js" type="text/javascript"></script>
  6. <script type="text/javascript">
  7. if(typeof FileReader == "undified") {
  8. alert("您老的浏览器不行了!");
  9. }
  10. function showDataByURL() {
  11. var resultFile = document.getElementById("fileDemo").files[0];
  12. if (resultFile) {
  13. var reader = new FileReader();
  14. reader.readAsDataURL(resultFile);
  15. reader.onload = function (e) {
  16. var urlData = this.result;
  17. document.getElementById("result").innerHTML += "<img src='" + urlData + "' alt='" + resultFile.name + "' />";
  18. };
  19. }
  20. }
  21. function showDataByBinaryString() {
  22. var resultFile = document.getElementById("fileDemo").files[0];
  23. if (resultFile) {
  24. var reader = new FileReader();
  25. //异步方式,不会影响主线程
  26. reader.readAsBinaryString(resultFile);
  27. reader.onload = function(e) {
  28. var urlData = this.result;
  29. document.getElementById("result").innerHTML += urlData;
  30. };
  31. }
  32. }
  33. function showDataByText() {
  34. var resultFile = document.getElementById("fileDemo").files[0];
  35. if (resultFile) {
  36. var reader = new FileReader();
  37. reader.readAsText(resultFile,'gb2312');
  38. reader.onload = function (e) {
  39. var urlData = this.result;
  40. document.getElementById("result").innerHTML += urlData;
  41. };
  42. }
  43. }
  44. </script>
  45. </head>
  46. <body>
  47. <input type="file" name="fileDemo" id="fileDemo" multep/>
  48. <input type="button" value="readAsDataURL" id="readAsDataURL" onclick="showDataByURL();"/>
  49. <input type="button" value="readAsBinaryString" id="readAsBinaryString" onclick="showDataByBinaryString();"/>
  50. <input type="button" value="readAsText" id="readAsText" onclick="showDataByText();"/>
  51. <div id="result">
  52. </div>
  53. </body>
  54. </html>

四、总结


有了文件操作的API后,让JS进一步的操作本地文件的得到空前的加强,HTML5对于客户端Web应用得到进一步功能的提升,HTML5的趋势让Web更加富客户端化,而这些都需要让我们的HTML或者JS变得更加强大,而HTML5正是适时地推出了File API。

HTML5文件操作API的更多相关文章

  1. HTML5 文件操作API

    简介 我常常想,如果网络应用能够读取和写入文件与目录,将会非常方便.从离线转移到在线后,应用变得更加复杂,而文件系统方面的API的缺乏也一直阻碍着网络前进.存储二进制数据或与其进行交互不应局限于桌面. ...

  2. Html5 学习系列(四)文件操作API

    原文:Html5 学习系列(四)文件操作API 引言 在之前我们操作本地文件都是使用flash.silverlight或者第三方的activeX插件等技术,由于使用了这些技术后就很难进行跨平台.或者跨 ...

  3. paip.复制文件 文件操作 api的设计uapi java python php 最佳实践

    paip.复制文件 文件操作 api的设计uapi java python php 最佳实践 =====uapi   copy() =====java的无,要自己写... ====php   copy ...

  4. 文件的概念以及VC里的一些文件操作API简介

    文件的基本概念 所谓“文件”是指一组相关数据的有序集合. 这个数据集有一个名称,叫做文件名. 实际上在前面的各章中我们已经多次使用了文件,例如源程序文件.目标文件.可执行文件.库文件 (头文件)等.文 ...

  5. Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比

    Java文件操作API功能与Windows DOS命令和Linux Shell 命令类比: Unix/Linux (Bash) Windows(MS-DOS) Java 进入目录 cd cd - 创建 ...

  6. H5文件操作API

    引言 在之前我们操作本地文件都是使用flash.silverlight或者第三方的activeX插件等技术,由于使用了这些技术后就很难进行跨平台.或者跨浏览器.跨设备等情况下实现统一的表现,从另外一个 ...

  7. nodejs模块fs——文件操作api

    // fs模块常用api // 读取文件 .写入文件 .追加文件. 拷贝文件 .删除文件 // 读取文件 // fs.readFile(path[, options], callback) // fs ...

  8. HTML5学习之文件操作(九)

    之前我们操作本地文件都是使用flash.silverlight或者第三方的activeX插件等技术,由于使用了这些技术后就很进行跨平台的处理,另外就是让我们的web应用依赖了第三方的插件,而不是很独立 ...

  9. HTML5 本地文件操作之FileSystemAPI简介

    一.FileSystemAPI简介 HTML5的文件操作Api中 1.FileAPI,用于基础的客户端本地文件读取,目前大多数接口已经被主流浏览器支持,点击查看更多参考 2.FileSystemAPI ...

随机推荐

  1. PyTorch官方中文文档:torch.nn

    torch.nn Parameters class torch.nn.Parameter() 艾伯特(http://www.aibbt.com/)国内第一家人工智能门户,微信公众号:aibbtcom ...

  2. Keras官方中文文档:keras后端Backend

    所属分类:Keras Keras后端 什么是"后端" Keras是一个模型级的库,提供了快速构建深度学习网络的模块.Keras并不处理如张量乘法.卷积等底层操作.这些操作依赖于某种 ...

  3. Weex 初探

    Weex 初探 Weex 介绍 Weex 是阿里于 2016 年开源的一款开发框架,它的介绍是: Weex 是一个使用 Web 开发体验来开发高性能原生应用的框架. 它使用了 Web 技术来开发 An ...

  4. luogu【P2753】[USACO4.3]字母游戏Letter Game

    这个题...一开始看了很久题目(并且问了机房几个大佬)才明白题意.. (原题入口) 题意 大概是一开始给你一些字母出现的次数 你之后组成的单词(最多两个单词)每个字母出现次数 必须小于或等于标准(st ...

  5. 【洛谷1855】 榨取kkksc03

    题面 前面省去一堆背景内容 洛谷的运营组决定,如果一名oier向他的教练推荐洛谷,并能够成功的使用(成功使用的定义是:该团队有20个或以上的成员,上传10道以上的私有题目,布置过一次作业并成功举办过一 ...

  6. P2500 - 【DP合集】背包 bound

    题面 Description N 种物品,第 i 种物品有 s i 个,单个重量为 w i ,单个价值为 v i .现有一个限重为 W 的背包,求能容 纳的物品的最大总价值. Input 输入第一行二 ...

  7. sql注入之一次艰难的绕过-三层防护(oracle)

    打开:www.xxxx.com/news/detail.jsp?id=2862 我们经过测试知道此处含有sql注入.我们尝试下: http://www.xxxxxx.com/news/detail.j ...

  8. C++学习-9

    友元主要用于访问私有变量,友元函数跟所在位置的权限没有任何关系friend+函数声明 友元类通常设计为一种对数据操作或类之间传递消息的辅助类(注意一下顺序) Explicit就是要求严格的匹配,不允许 ...

  9. js操作DOM元素

    创建 document.createElement() 查找 document.getElementById()   返回对拥有指定 id 的第一个对象的引用. document.getElement ...

  10. 【原创】快应用QuickApp--HelloWorld体验

    快应用: 快应用是九大手机厂商基于硬件平台共同推出的新型应用生态.用户无需下载安装,即点即用,享受原生应用的性能体验. 3月20日在北京联合召开快应用标准启动发布会.过去1天了,官网(快应用官方网站) ...