亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

js讀取本地文件的實例

2019-11-19 14:40:09
字體:
來源:轉載
供稿:網友

如何用在瀏覽器端預覽本地文件?

今天的主題是使用瀏覽器預覽本地文件。

由于瀏覽器安全策略的限制,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, //選取的文件urlfile: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立即失效。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品人成电影| 日韩网站免费观看| 性欧美亚洲xxxx乳在线观看| 久久久精品久久久| 国产一区香蕉久久| 久久综合伊人77777尤物| 国产精品天天狠天天看| 国产一区二区三区四区福利| 精品视频在线导航| 中文国产成人精品| 欧美性黄网官网| 91精品免费久久久久久久久| 国产精品免费久久久久久| 美女撒尿一区二区三区| 久久视频国产精品免费视频在线| 成人伊人精品色xxxx视频| 福利二区91精品bt7086| 亚洲精品欧美一区二区三区| 26uuu另类亚洲欧美日本一| 亚洲天堂男人天堂女人天堂| 日本欧美在线视频| 欧美激情一区二区久久久| 中文字幕日韩欧美| 揄拍成人国产精品视频| 亚洲a成v人在线观看| 欧美精品少妇videofree| 亚洲国产另类久久精品| 色综合久久精品亚洲国产| 欧美成aaa人片免费看| 亚洲成人激情在线观看| 成人免费视频网| 久久视频在线直播| 国产精品美女主播在线观看纯欲| 中文字幕亚洲综合| 777777777亚洲妇女| 97精品国产97久久久久久| 亚洲va电影大全| 亚洲成人精品久久久| 中文字幕亚洲在线| 日韩中文字幕久久| 国产亚洲免费的视频看| 亚洲精品不卡在线| 日本伊人精品一区二区三区介绍| 亚洲自拍偷拍在线| 成人免费网站在线| 欧美中文在线免费| 成人免费福利在线| 精品视频久久久久久久| 欧美尤物巨大精品爽| 国产精品久久久久久亚洲影视| 久久亚洲国产精品成人av秋霞| 91九色国产视频| www.日韩欧美| 国产精品午夜一区二区欲梦| 亚洲欧美精品中文字幕在线| 国产精品jvid在线观看蜜臀| 夜夜嗨av一区二区三区免费区| 欧美日韩xxx| 久久久久久久久久久免费精品| 国产丝袜精品第一页| 欧美疯狂xxxx大交乱88av| 狠狠色香婷婷久久亚洲精品| 国产精品成人av在线| 精品日本高清在线播放| 国产视频久久久久| 亚洲片国产一区一级在线观看| 日本aⅴ大伊香蕉精品视频| 成人在线一区二区| 久久人91精品久久久久久不卡| 欧美在线视频免费观看| 亚洲国产精品久久久久久| 国产精品pans私拍| 久久人人爽人人爽人人片av高清| 欧美日韩国产成人在线| 日韩欧美国产视频| 日韩av片电影专区| 久久精品青青大伊人av| 国产精品色午夜在线观看| 国产精品观看在线亚洲人成网| 国产精品精品久久久久久| 欧美视频在线视频| 国产丝袜精品视频| 成人黄色短视频在线观看| 这里只有精品视频| 中文字幕精品在线| 国产91精品最新在线播放| 久久免费视频网站| 在线精品高清中文字幕| 国产精品国产亚洲伊人久久| 久久精品亚洲94久久精品| 伊人亚洲福利一区二区三区| 成人在线精品视频| 精品无人区乱码1区2区3区在线| 久久影院资源网| 欧美日韩午夜剧场| 午夜精品福利在线观看| 亚洲女人初尝黑人巨大| 国产精品露脸av在线| 国产精品永久免费视频| 国产精品久久久久久久久久ktv| 欧美大片va欧美在线播放| 国产免费一区二区三区在线能观看| 亚洲一区二区久久| 成人亚洲综合色就1024| 亚洲视频在线播放| 成人福利在线视频| 欧日韩不卡在线视频| 久久国产精品久久久久| 久久久久国产精品www| 亚洲xxxx妇黄裸体| 精品久久久久久| 亚洲精品91美女久久久久久久| 久久精品视频中文字幕| 中文国产亚洲喷潮| 日韩高清免费观看| 欧美日韩国产色视频| 国产免费成人av| 欧美激情三级免费| 国产精品男人的天堂| 亚洲性av网站| 亚洲www在线| 亚洲最大av在线| 国产精品美女久久久久av超清| 国产精品高清网站| 欧美日韩国产在线| 国产精品视频免费在线| 中文字幕av一区二区三区谷原希美| 欧美成人sm免费视频| 亚洲一级一级97网| 国产在线久久久| 色哟哟网站入口亚洲精品| 久久久久久久久中文字幕| 欧美在线性爱视频| 69av在线播放| 国产精品久久99久久| 96精品久久久久中文字幕| 欧美国产在线电影| 亚洲aa中文字幕| 欧美日本国产在线| 欧美丝袜一区二区三区| 国产第一区电影| 亚洲美女又黄又爽在线观看| 欧美第一页在线| 亚洲国产精品国自产拍av秋霞| 国产91色在线免费| 日韩视频欧美视频| 亚洲区bt下载| 伊人青青综合网站| 久久人人97超碰精品888| 91夜夜揉人人捏人人添红杏| 国产精品第2页| 国产成人精品免高潮在线观看| 91丨九色丨国产在线| 欧美午夜性色大片在线观看| 91久热免费在线视频| 青青久久av北条麻妃海外网| 欧美日韩久久久久| 欧美精品videos| 国产精品免费一区豆花| 国产亚洲精品久久久| 国产欧美精品va在线观看| 国产精品露脸av在线| 久久久久久综合网天天| 亚洲人成电影在线观看天堂色|