js读取本地文件的实例


Posted in Javascript onDecember 22, 2017

如何用在浏览器端预览本地文件?

今天的主题是使用浏览器预览本地文件。

由于浏览器安全策略的限制,javascript程序不能自由地访问本地资源,这是对用户信息安全来说,是一项不得不遵守的准则。假如网络上的javascript程序可以自如地访问用户主机的本地资源,那么浏览器用户将毫无安全可言。尽管有这个安全限制,但是在得到用户允许的情况下,浏览器还是可以访问本地资源的。

获得用户允许的方法就是通过标签来让用户手动选择文件,这一过程就是用户授予访问权限的过程。然后 使用获得File 对象通过URL.createObjectURL(file)转换为文件url, 就可以传递给类似y于img,video,audio等标签使用了。我将本地文件转换为url 的功能封装成了一个类。

function LocalFileUrl(){
 var _this = this;
 this.input_id = 'input_getLocalFile'+ Math.round(Math.random() * 1000);
 $("body").append("<input type='file' style='display:none' id='"+this.input_id+"' multiple>");
 this.urls=[];
 var _this = this;
 $("#" + this.input_id).change(function(e){
  console.log("change");
  //如果_this.urls 不为空,则释放url
  if(_this.urls){
   _this.urls.forEach(function(url,index,array){
    URL.revokeObjectURL(url.url);//一经释放,马上将无法使用这个url的资源
   });
   _this.urls = [];
  }
  $(this.files).each(function(index,file){
   var url = URL.createObjectURL(file);
   _this.urls.push({url:url,file:file});
  });
  typeof _this.getted == 'function' && _this.getted(_this.urls);
 })
}
/*
参数说明:getted:function(urls){}
urls是一个url对象数组。[url]
url = {
url:url, //选取的文件url
file:file //选取的文件对象引用
}
*/
LocalFileUrl.prototype.getUrl = function(getted){
 this.getted = getted;
 $("#"+ this.input_id).click();
}

使用方法:

var localFileUrl = new LocalFileUrl();//实例化对象
//触发读取,弹出文件选择框,并且监听文件选择事件。  
localFileUrl.getUrl(function(urls){
 urls.forEach(function(item,index,array){
  $("body").append("<div>"+index+"----"+item.url+"</div>")
 })
})

使用jQuery 的promise对象改写

这种方式的好处是可以使用链式写法,并且可以绑定多个done事件处理函数,执行顺序按照绑定顺序。

function LocalFileUrl(){
 this.dtd ={};
 this.input_id = 'input_getLocalFile'+ Math.round(Math.random() * 1000);
 $("body").append("<input type='file' style='display:none' id='"+this.input_id+"' multiple>");
 this.urls=[];
 var _this = this;
 $("#" + this.input_id).change(function(e){
  //如果_this.urls 不为空,则释放url
  if(_this.urls){
   _this.urls.forEach(function(url,index,array){
    URL.revokeObjectURL(url.url);//一经释放,马上将无法使用这个url的资源
   });
   _this.urls = [];
  }
  $(this.files).each(function(index,file){
   var url = URL.createObjectURL(file);
   _this.urls.push({url:url,file:file});
  });
  //传入一个可选的参数数组
  _this.dtd.resolveWith(window,new Array(_this.urls));
 })
}
/*
返回一个jquery 的promise 对象,可以绑定done()事件。done(urls)接收一个urls数组
{
 url:url,
 file:file// 选取的文件对象
}
*/
LocalFileUrl.prototype.getUrl = function(){
 this.dtd = $.Deferred();
 $("#"+ this.input_id).click();
 return this.dtd.promise();
}

使用方式

var localFilrUrl = new LocalFileUrl();
// 绑定done事件
localFileUrl.getUrl().done(function(urls){
 urls.forEach(function(item,index,array){
  $("body").append("<div>"+index+"----"+item.url+"</div>")
 })
}).done(function(){
 console.log("完成");
}).done(function(){
 alert("已经读取了本地文件路径");
})

兼容性

URL.createObjectURL(File/Blob)是一个实验性的功能。IE10及以上版本兼容。与之对应的是URL.revokeObjectURL(url),它用来告诉浏览器已经不需要这个url的引用了,可以释放掉了。一经调用,这个url立即失效。

Javascript 相关文章推荐
Javascript公共脚本库系列(一): 弹出层脚本
Feb 24 Javascript
简单的jquery左侧导航栏和页面选中效果
Aug 21 Javascript
JavaScript中最简洁的编码html字符串的方法
Oct 11 Javascript
jQuery中first()方法用法实例
Jan 06 Javascript
javascript实现列表滚动的方法
Jul 30 Javascript
JavaScript代码因逗号不规范导致IE不兼容的问题
Feb 25 Javascript
js实现炫酷的左右轮播图
Jan 18 Javascript
老生常谈js-react组件生命周期
May 02 Javascript
Ionic3 UI组件之Gallery Modal详解
Jun 07 Javascript
解决html-jquery/js引用外部图片时遇到看不了或出现403的问题
Sep 22 jQuery
详解vue中router-link标签所必备了解的属性
Apr 15 Javascript
用node.js写一个jenkins发版脚本
May 21 Javascript
javascript将json格式数组下载为excel表格的方法
Dec 22 #Javascript
原生js实现移动端触摸轮播的示例代码
Dec 22 #Javascript
JavaScript多线程运行库Nexus.js详解
Dec 22 #Javascript
JS实现在文本指定位置插入内容的简单示例
Dec 22 #Javascript
JavaScript实现单例模式实例分享
Dec 22 #Javascript
vue使用axios时关于this的指向问题详解
Dec 22 #Javascript
Javascript中JSON数据分组优化实践及JS操作JSON总结
Dec 22 #Javascript
You might like
一贴学会PHP 新手入门教程
2009/08/03 PHP
详解php伪造Referer请求反盗链资源
2019/01/24 PHP
laravel 框架结合关联查询 when()用法分析
2019/11/22 PHP
JS 日期验证正则附asp日期格式化函数
2009/09/11 Javascript
jQuery移除tr无效的解决方法(tr是动态添加)
2014/09/22 Javascript
javascript每日必学之继承
2016/02/23 Javascript
JS判断字符串字节数并截取长度的方法
2016/03/05 Javascript
js多功能分页组件layPage使用方法详解
2016/05/19 Javascript
jQuery Ajax 加载数据时异步显示加载动画
2016/08/01 Javascript
js前端面试题及答案整理(一)
2016/08/26 Javascript
JS中常用的正则表达式
2016/09/29 Javascript
js获取ip和地区
2017/03/10 Javascript
Vue 过渡实现轮播图效果
2017/03/27 Javascript
vue-cli单页应用改成多页应用配置详解
2017/07/14 Javascript
elementui之el-tebs浏览器卡死的问题和使用报错未注册问题
2019/07/06 Javascript
JavaScript 继承 封装 多态实现及原理详解
2019/07/29 Javascript
vscode 配置vue+vetur+eslint+prettier自动格式化功能
2020/03/23 Javascript
使用纯前端JavaScript实现Excel导入导出方法过程详解
2020/08/07 Javascript
约瑟夫问题的Python和C++求解方法
2015/08/20 Python
Django Highcharts制作图表
2016/08/27 Python
python实现求最长回文子串长度
2018/01/22 Python
python版本的仿windows计划任务工具
2018/04/30 Python
Python BS4库的安装与使用详解
2018/08/08 Python
Python谱减法语音降噪实例
2019/12/18 Python
利用Python计算KS的实例详解
2020/03/03 Python
Pycharm中import torch报错的快速解决方法
2020/03/05 Python
Python自动化操作实现图例绘制
2020/07/09 Python
python绘制趋势图的示例
2020/09/17 Python
详解python日志输出使用配置文件格式
2021/02/10 Python
英国儿童鞋和靴子:Start-Rite
2019/05/06 全球购物
屈臣氏马来西亚官网:Watsons马来西亚
2019/06/15 全球购物
美国孕妇装购物网站:Motherhood Maternity
2019/09/22 全球购物
什么是唯一索引
2015/07/05 面试题
公开服务承诺制度
2014/03/26 职场文书
药剂专业毕业生求职信
2014/06/24 职场文书
Win11怎么修改电源模式?Win11修改电源模式的方法
2022/04/05 数码科技