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 相关文章推荐
jquery 插件 人性化的消息显示
Jan 21 Javascript
jquery 批量上传图片实现代码
Jan 28 Javascript
JavaScript 原型继承之构造函数继承
Aug 26 Javascript
Javascript保存网页为图片借助于html2canvas库实现
Sep 05 Javascript
window.onload与$(document).ready()的区别分析
May 30 Javascript
轻松实现Bootstrap图片轮播
Apr 20 Javascript
正则表达式,替换所有HTML标签的简单实例
Nov 28 Javascript
React学习笔记之条件渲染(一)
Jul 02 Javascript
vue-ajax小封装实例
Sep 18 Javascript
微信小程序实现选项卡效果
Nov 06 Javascript
微信网页登录逻辑与实现方法
Apr 29 Javascript
vue登录以及权限验证相关的实现
Oct 25 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
动态新闻发布的实现及其技巧
2006/10/09 PHP
php下载远程文件类(支持断点续传)
2008/11/14 PHP
在PHP中运行Linux命令并启动SSH服务的例子
2014/06/12 PHP
Ecshop 后台添加新功能栏目及管理权限设置教程
2017/11/21 PHP
jWiard 基于JQuery的强大的向导控件介绍
2011/10/28 Javascript
首页图片漂浮效果示例代码
2014/06/05 Javascript
jQuery地图map悬停显示省市代码分享
2015/08/20 Javascript
js实现超简单的展开、折叠目录代码
2015/08/28 Javascript
基于JS实现简单的样式切换效果代码
2015/09/04 Javascript
JavaScript必知必会(二) null 和undefined
2016/06/08 Javascript
Javascript函数中的arguments.callee用法实例分析
2016/09/16 Javascript
运用js教你轻松制作html音乐播放器
2020/04/17 Javascript
JavaScript仿微博发布信息案例
2016/11/16 Javascript
JavaScript中利用构造器函数模拟类的方法
2017/02/16 Javascript
selenium 与 chrome 进行qq登录并发邮件操作实例详解
2017/04/06 Javascript
Angular2管道Pipe及自定义管道格式数据用法实例分析
2017/11/29 Javascript
vue项目中v-model父子组件通信的实现详解
2017/12/10 Javascript
JS中DOM元素的attribute与property属性示例详解
2018/09/04 Javascript
vue 进阶之实现父子组件间的传值
2019/04/26 Javascript
微信小程序设置滚动条过程详解
2019/07/25 Javascript
layui上传图片到服务器的非项目目录下的方法
2019/09/26 Javascript
VUE实时监听元素距离顶部高度的操作
2020/07/29 Javascript
Python安装模块的常见问题及解决方法
2018/02/05 Python
python如何求解两数的最大公约数
2018/09/27 Python
Python面向对象程序设计OOP深入分析【构造函数,组合类,工具类等】
2019/01/05 Python
HTML文本属性&amp;颜色控制属性的实现
2019/12/17 HTML / CSS
Pat McGrath Labs官网:世界上最有影响力的化妆师推出的彩妆品牌
2018/01/07 全球购物
美国名牌香水折扣网站:Hottperfume
2021/02/10 全球购物
创业计划书撰写原则
2014/01/25 职场文书
单位授权委托书范文
2014/08/02 职场文书
新颖的化妆品活动方案
2014/08/21 职场文书
单位综合评价意见
2015/06/05 职场文书
一个家长教育孩子的心得体会
2016/01/15 职场文书
利用Java设置Word文本框中的文字旋转方向的实现方法
2021/06/28 Java/Android
nginx结合openssl实现https的方法
2021/07/25 Servers
python脚本框架webpy的url映射详解
2021/11/20 Python