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 相关文章推荐
List the UTC Time on a Computer
Jun 11 Javascript
JavaScript中的比较操作符&gt;、=、
Dec 31 Javascript
js获取域名的方法
Jan 27 Javascript
js的flv视频播放器插件使用方法
Jun 23 Javascript
一道常被人轻视的web前端常见面试题(JS)
Feb 15 Javascript
js轮播图代码分享
Jul 14 Javascript
jquery使用EasyUI Tree异步加载JSON数据(生成树)
Feb 11 Javascript
jQuery插件之validation插件
Mar 29 jQuery
浅谈vue-lazyload实现的详细过程
Aug 22 Javascript
jQuery中可见性过滤器简单用法示例
Mar 31 jQuery
Vue中Object.assign清空数据报错的解决方案
Mar 03 Vue.js
vue3种table表格选项个数的控制方法
Apr 14 Vue.js
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实现在多维数组中查找特定value的方法
2015/07/29 PHP
laravel框架模型中非静态方法也能静态调用的原理分析
2019/11/23 PHP
jQuery学习4 浏览器的事件模型
2010/02/07 Javascript
jquery链式操作的正确使用方法
2014/01/06 Javascript
jQuery实现统计复选框选中数量
2014/11/24 Javascript
jQuery获得子元素个数的方法
2015/04/14 Javascript
NodeJS使用formidable实现文件上传
2016/10/27 NodeJs
jquery ajax后台返回list,前台用jquery遍历list的实现
2016/10/30 Javascript
iscroll.js滚动加载实例详解
2017/07/18 Javascript
基于构造函数的五种继承方法小结
2017/07/27 Javascript
Vue循环组件加validate多表单验证的实例
2018/09/18 Javascript
Node如何后台数据库使用增删改查功能
2019/11/21 Javascript
js实现左右轮播图
2020/01/09 Javascript
详解Vue3中对VDOM的改进
2020/04/23 Javascript
Eclipse + Python 的安装与配置流程
2013/03/05 Python
Python实例之wxpython中Frame使用方法
2014/06/09 Python
Python自定义进程池实例分析【生产者、消费者模型问题】
2016/09/19 Python
深入理解python中sort()与sorted()的区别
2018/08/29 Python
python爬虫获取百度首页内容教学
2018/12/23 Python
Python3+Pycharm+PyQt5环境搭建步骤图文详解
2019/05/29 Python
pandas 时间格式转换的实现
2019/07/06 Python
Python符号计算之实现函数极限的方法
2019/07/15 Python
Django 在iframe里跳转顶层url的例子
2019/08/21 Python
Python imageio读取视频并进行编解码详解
2019/12/10 Python
Django restframework 框架认证、权限、限流用法示例
2019/12/21 Python
利用Python脚本批量生成SQL语句
2020/03/04 Python
Python ORM框架Peewee用法详解
2020/04/29 Python
程序设计HTML5 Canvas API
2013/04/08 HTML / CSS
新闻专业学生的自我评价
2014/02/13 职场文书
工作会议主持词
2014/03/17 职场文书
竞选村长演讲稿
2014/04/28 职场文书
创先争优活动党员公开承诺书
2014/08/29 职场文书
大学生团员个人总结
2015/02/14 职场文书
幼儿园班级工作总结2015
2015/05/25 职场文书
导游词之秦皇岛燕塞湖
2020/01/03 职场文书
JAVA长虹键法之建造者Builder模式实现
2022/04/10 Java/Android