简单地说,File API只规定怎样从硬盘上提取文件,然后交给在网页中运行的JavaScript代码。

与以往文件上传不一样,File API不是为了向服务器提交文件设计的。

关于File API不能做什么也非常值得注意。它不能修改文件,也不能创建新文件。

想保存任何数据,你可以通过Ajax把数据发送到服务器,或者把它保存在本地存储空间中。

取得文件

  • 使用input元素。将其type属性设置为file,这样是最常见的标准上传文本框
  • 隐藏的input元素。为了保证风格一致,可以把input元素隐藏起来,显示一个漂亮的按钮。

    用户点击按钮时,通过JS调用隐藏的input的click事件
  • 拖放。把文件拖放到网页上

读取文本文件readAsText()

使用File API可以直接读取文件文件的内容。创建一个例子

<input name="myAvatar" type="file" onchange="processFiles(this.files)" />

选择一个文件后,会触发这个input元素的onChange事件,因而就会执行processFiles()函数

var output = document.getElementById('fileOutput');
var processFiles = function(files) {
// 一次只允许上传一个文件
var file = files[0];
var reader = new FileReader(); reader.onload = function(e) {
output.textContent = e.target.result;
}
reader.readAsText(file);
};

每个文件对象都有三个有用的属性:name,保存文件名。size保存文件的字节大小。 type

保存文件的MIME类型

一次读取多个文件multiple

为input元素添加multiple属性,一次可以读取多个文件

<input name="myAvatar" type="file" multiple onchange="processFiles(this.files)" />

循环处理多文件。注意onLoad事件是异步的

var processFiles = function(files) {
var fileContents = []; for(var i=0, len = files.length; i< len; i++) {
// 每个文件建立一个文件句柄
var reader = new FileReader();
// 由于onload是异步处理函数,使用闭包记录i值。否则i一直等于len
(function(i) {
reader.onload = function(e) {
fileContents.push(e.target.result);
if(i === len - 1) {
output.textContent = fileContents.join('\n\n\n');
}
}
})(i)
reader.readAsText(files[i]);
}
};

读取图片文件readAsDataURL()

FileReader处理文本内容只需要一步。同样,处理图片内容也这么简单。

这归功于readAsDataURL()方法。

下面的例子涉及处理图片和文件拖放。提交的图片文件用于绘制元素的背景。

var dropBox;
document.addEventListener('DOMContentLoaded', function() {
dropBox = document.getElementById('dropbox');
dropbox.addEventListener('dragenter', ignoreDrag, false);
dropbox.addEventListener('dragover', ignoreDrag, false);
dropbox.addEventListener('drop', drop, false);
}, false)
var processFiles = function(files) {
var file = files[0];
var reader = new FileReader();
reader.onload = function(e) {
dropBox.style.backgroundImage = 'url(' + e.target.result + ')';
}; // 读取图片
reader.readAsDataURL(file);
};
var ignoreDrag = function(e) {
e.stopPropagation();
e.preventDefault();
};
var drop = function(e) {
ignoreDrag(e); var data = e.dataTransfer;
var files = data.files;
processFiles(files);
};

下面是html和css

<div id="dropbox">
<div>Drop your image here</div>
</div>
#dropbox {
margin: 15px; width: 300px; height: 300px;
border: 5px dashed gray; border-radius: 8px;
background: lightyellow; background-size: 100%;
background-repeat: no-repeat; text-align: center;
}
#dropbox div { margin: 100px 70px; color: orange; font-size: 25px; }

更新2014/07/10

对异步循环使用递归

var processFiles = function(files) {
var filesLen = files.length
, reader = null
, fileContents = []
, readFile = function(i) {
if(i === filesLen) { // 递归的结束条件
output.textContent = fileContents.join('\n\n\n');
return;
}
reader = new FileReader();
reader.onload = function(e) {
fileContents.push(e.target.result);
readFile(i+1); // 保证输出顺序
};
reader.readAsText(files[i]);
}; if(!filesLen) return;
readFile(0); // 开始递归
};

参考:the missing manual

File API 读取文件小结的更多相关文章

  1. HTML5 file api读取文件的MD5码工具

    1.工具的用途:用HTML5 file api读取文件的MD5码.MD5码在文件的唯一性识别上有很重要的应用,业内常用MD5进行文件识别.文件秒传.文件安全性检查等: 2.适用性:IE.Chrome皆 ...

  2. HTML5的File API读取文件信息

    html结构: <div id="fileImage"></div> <input type="file" value=" ...

  3. 使用 JavaScript File API 实现文件上传

    概述 以往对于基于浏览器的应用而言,访问本地文件都是一件头疼的事情.虽然伴随着 Web 2.0 应用技术的不断发展,JavaScript 正在扮演越来越重要的角色,但是出于安全性的考虑,JavaScr ...

  4. Java8 新API读取文件内容

    import java.io.IOException;import java.nio.charset.Charset;import java.nio.file.Files;import java.ni ...

  5. Resumable.js – 基于 HTML5 File API 的文件上传

    Resumable.js 是一个 JavaScript 库,通过 HTML5 文件 API 提供,稳定和可恢复的批量上传功能.在上传大文件的时候通过每个文件分割成小块,每块在上传失败的时候,上传会不断 ...

  6. File API 读取上传的文件

    1, 在html 文档中,<input type="file"> 我们可以选择文件进行上传,但这时只能上传一个文件.如果加上multiple 属性,可以上传多个文件,上 ...

  7. 网鼎杯-Fakebook-反序列化和SSRF和file协议读取文件

    0x00知识点:SSRF SSRF (Server-side Request Forge, 服务端请求伪造) 是一种由攻击者构造形成由服务端发起请求的一个安全漏洞.一般情况下,SSRF攻击的目标是从外 ...

  8. resumable.js —— 基于 HTML 5 File API 的文件上传组件 支持续传后台c#实现

    在git上提供了java.nodejs.c#后台服务方式:在这里我要用c#作为后台服务:地址请见:https://github.com/23/resumable.js 我现在visual studio ...

  9. 使用FileSystem自带的api读取hdfs中的文件

    博客搬家自https://my.oschina.net/itsyizu/blog/ 1. 创建hadoop MapReduce项目 输入项目名称 创建好的项目初始化状态如下 编写java类 impor ...

随机推荐

  1. SharedPreferences漏洞, 无法避免,所以不要在里面存储敏感信息

     1. SharedPreferences漏洞, 无法避免,所以不要在里面存储敏感信息2. 数据存储检测,content://com.starcor.launcherInfo/deviceInfo&q ...

  2. 三道Javascript的练习题

    有语句“var x=0;while(____) x+=2;”,要使while循环体执行10次,空白处的循环判定式应写为: A.x<10B. x<=10C.x<20D.x<=20 ...

  3. 前端Demo常用库文件链接

    <!doctype html><html><head> <meta charset="UTF-8"> <title>前端 ...

  4. 《javascript面向对象精要》读书笔记

    <javascript面向对象精要> 买这本书的原因主要是因为作者,Nicholas C. Zakas 牛X闪闪的js专家,读过js高程的应该都知道他,而这本书是他的最新力作,感觉也是js ...

  5. iOS 支付宝的使用

    支付宝相关资源下载地址:支付宝开放平台  在移动支付功能处下载. 一.使用官方的Demo 需要配置基本信息: 打开“APViewController.m”文件,对以下三个参数进行编辑. 二.集成支付宝 ...

  6. iOS适配 旧项目工程在iOS9下不能正常显示

    在iOS开发中,很多时候会用到旧项目,比如版本的升级.使用Demo等等, iOS SDK正在不断的升级,不断的升级给iOS开发带来了新的活力. 然而在iOS SDK新的版本出来之后,旧项目可能会出现新 ...

  7. 把Sharepoint Desinger 工作流部署到生产环境

    下面是比较简单的方法,把Designer工作流从开发环境部署到生产环境. 在Sharepoint Desinger 2013 中点击需要部署的工作流. 点击保存,发布. 点Export to Visi ...

  8. iOS 学习 - 17.Socket

    Socket 是应用层与 TCP / IP 协议通信的中间软件抽象层,它是一组接口   TCP:面向连接.传输可靠(保证数据正确性,保证数据顺序).用于传输大量数据(流模式).速度慢,建立连接需要开销 ...

  9. iOS开发之功能模块--Apns推送中的的json格式介绍

    在开发向苹果Apns推送消息服务功能,我们需要根据Apns接受的数据格式进行推送.下面接受我在进行apns推送时候总结的一点apns服务接受的Json数据格式 示例 1: 以下负载包含哦一个简单的 a ...

  10. 关于Hibernate 的数据库配置

    <hibernate-configuration>    <session-factory name="mySessionFactory">        ...