欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于javascript html5實(shí)現(xiàn)多文件上傳

 更新時(shí)間:2016年03月03日 08:49:48   作者:weapon-x  
這篇文章主要為大家詳細(xì)介紹了基于javascript html5實(shí)現(xiàn)多文件上傳的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了javascript html5實(shí)現(xiàn)多文件上傳的實(shí)現(xiàn)方法,具體內(nèi)容如下

HTML結(jié)構(gòu):

<div class="container">
 <label>請(qǐng)選擇一個(gè)圖像文件:</label>
 <input type="file" id="file_input" multiple/>
</div>

順便說(shuō)下這個(gè)上傳的主要邏輯:

  • 用input標(biāo)簽并選擇type=file,記得帶上multiple,不然就只能單選圖片了
  • 綁定好input的change時(shí)間,
  • 重點(diǎn)就是如何處理這個(gè)change事件了,使用H5新的FileReader接口讀取文件并打成base64編碼,之后的事就是與后端同學(xué)交互著玩啦

JS代碼:

window.onload = function(){
  var input = document.getElementById("file_input");
  var result,div;
 
  if(typeof FileReader==='undefined'){
   result.innerHTML = "抱歉,你的瀏覽器不支持 FileReader";
   input.setAttribute('disabled','disabled');
  }else{
   input.addEventListener('change',readFile,false);
  }<br>     //handler
  function readFile(){
   for(var i=0;i<this.files.length;i++){
    if (!input['value'].match(/.jpg|.gif|.png|.bmp/i)){  //判斷上傳文件格式
     return alert("上傳的圖片格式不正確,請(qǐng)重新選擇")<br>          }
    var reader = new FileReader();
    reader.readAsDataURL(this.files[i]);
    reader.onload = function(e){
     result = '<div id="result"><img src="'+this.result+'" alt=""/></div>';
     div = document.createElement('div');
     div.innerHTML = result;
     document.getElementById('body').appendChild(div);   //插入dom樹      <br>          }
   }
  }
 }

上傳多張圖片難道就這樣實(shí)現(xiàn)了嗎?

然而并沒(méi)有,這樣只是將圖片轉(zhuǎn)換成base64編碼后再前端顯示,一刷新什么都沒(méi)有

插入圖片后,打開開發(fā)者工具看html結(jié)構(gòu)是這樣的

 

現(xiàn)實(shí)的做法是,我們?cè)谔幚砗瘮?shù)里將文件隊(duì)列里的文件發(fā)送到后端,后端同學(xué)呢返回文件對(duì)應(yīng)的MD5加密過(guò)文件和路徑給前端,前端就拿著這個(gè)路徑渲染到頁(yè)面上。

之后再把MD5文件傳回給后端,因?yàn)樯蟼魍旰笄岸艘话阌袆h除圖片的操作,回傳目的就是告訴后端確認(rèn)那些圖片是我們想要的,后端存入數(shù)據(jù)庫(kù)里。

說(shuō)下用jquery如何交互吧

function readFile(){
   var fd = new FormData();
   for(var i=0;i<this.files.length;i++){
    var reader = new FileReader();
    reader.readAsDataURL(this.files[i]);
    fd.append(i,this.files[i]);<br>          }
    $.ajax({
     url : '',
     type : 'post',
     data : fd,
     success : function(data){
      console.log(data)
      } 
    })
} 

FormData也是H5的新接口,用來(lái)模擬表單控件的提交,最大的好處呢就是可以提交二進(jìn)制文件

然后success的回調(diào)里面我們拿回了想要的數(shù)據(jù)后呢,就可以將圖片插進(jìn)去頁(yè)面啦,類似之前的做法~

上個(gè)效果圖:

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。

相關(guān)文章

  • 詳解如何在 JavaScript 中使用三元運(yùn)算符

    詳解如何在 JavaScript 中使用三元運(yùn)算符

    這篇文章主要為大家介紹了詳解如何在 JavaScript 中使用三元運(yùn)算符示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • JS實(shí)現(xiàn)分頁(yè)導(dǎo)航效果

    JS實(shí)現(xiàn)分頁(yè)導(dǎo)航效果

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)動(dòng)態(tài)頁(yè)碼及分頁(yè)導(dǎo)航,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • ES6擴(kuò)展運(yùn)算符的使用方法示例

    ES6擴(kuò)展運(yùn)算符的使用方法示例

    es6新增加了一個(gè)運(yùn)算符,叫做擴(kuò)展運(yùn)算符,這個(gè)運(yùn)算符用在數(shù)組前面,會(huì)把數(shù)組展開變成各個(gè)獨(dú)立的值,這篇文章主要給大家介紹了關(guān)于ES6擴(kuò)展運(yùn)算符的相關(guān)資料,需要的朋友可以參考下
    2021-07-07
  • 微信小程序傳值(傳遞數(shù)據(jù))的一些方法匯總

    微信小程序傳值(傳遞數(shù)據(jù))的一些方法匯總

    在微信小程序的開發(fā)中,我們會(huì)經(jīng)常遇到頁(yè)面間數(shù)據(jù)傳遞或者相互影響的問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于微信小程序傳值(傳遞數(shù)據(jù))的一些方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(五):經(jīng)典KMP算法

    JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(五):經(jīng)典KMP算法

    這篇文章主要介紹了JavaScript中數(shù)據(jù)結(jié)構(gòu)與算法(五):經(jīng)典KMP算法,本文詳解了KMP算法的方方面在,需要的朋友可以參考下
    2015-06-06
  • 詳解微信小程序canvas圓角矩形的繪制的方法

    詳解微信小程序canvas圓角矩形的繪制的方法

    這篇文章主要介紹了詳解微信小程序canvas圓角矩形的繪制的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 如何在CocosCreator中使用JSZip壓縮

    如何在CocosCreator中使用JSZip壓縮

    這篇文章主要介紹了在CocosCreator中使用JSZip壓縮,對(duì)JSZip感興趣的同學(xué),不妨看一下,并且親自試一試
    2021-04-04
  • js正則表達(dá)式惰性匹配和貪婪匹配用法分析

    js正則表達(dá)式惰性匹配和貪婪匹配用法分析

    這篇文章主要介紹了js正則表達(dá)式惰性匹配和貪婪匹配用法,結(jié)合實(shí)例形式詳細(xì)分析了正則表達(dá)式的基本概念以及惰性匹配和貪婪匹配的使用方法,需要的朋友可以參考下
    2016-12-12
  • Javascript技術(shù)棧中的四種依賴注入詳解

    Javascript技術(shù)棧中的四種依賴注入詳解

    這篇文章主要為大家詳細(xì)介紹了Javascript技術(shù)棧中的四種依賴注入,感興趣的小伙伴們可以參考一下
    2016-02-02
  • Bootstrap按鈕組件詳解

    Bootstrap按鈕組件詳解

    按鈕組和下拉菜單組件一樣,需要依賴于button.js插件才能正常運(yùn)作。通過(guò)本文給大家詳細(xì)介紹Bootstrap按鈕組件,感興趣的朋友一起學(xué)習(xí)吧
    2016-04-04

最新評(píng)論