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

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

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

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

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

<div class="container">
 <label>請選擇一個圖像文件:</label>
 <input type="file" id="file_input" multiple/>
</div>

順便說下這個上傳的主要邏輯:

  • 用input標(biāo)簽并選擇type=file,記得帶上multiple,不然就只能單選圖片了
  • 綁定好input的change時間,
  • 重點就是如何處理這個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("上傳的圖片格式不正確,請重新選擇")<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>          }
   }
  }
 }

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

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

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

 

現(xiàn)實的做法是,我們在處理函數(shù)里將文件隊列里的文件發(fā)送到后端,后端同學(xué)呢返回文件對應(yīng)的MD5加密過文件和路徑給前端,前端就拿著這個路徑渲染到頁面上。

之后再把MD5文件傳回給后端,因為上傳完后前端一般有刪除圖片的操作,回傳目的就是告訴后端確認(rèn)那些圖片是我們想要的,后端存入數(shù)據(jù)庫里。

說下用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的新接口,用來模擬表單控件的提交,最大的好處呢就是可以提交二進(jìn)制文件

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

上個效果圖:

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

相關(guān)文章

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

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

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

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

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

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

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

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

    在微信小程序的開發(fā)中,我們會經(jīng)常遇到頁面間數(shù)據(jù)傳遞或者相互影響的問題,下面這篇文章主要給大家介紹了關(guān)于微信小程序傳值(傳遞數(shù)據(jù))的一些方法,文中通過實例代碼介紹的非常詳細(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圓角矩形的繪制的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • 如何在CocosCreator中使用JSZip壓縮

    如何在CocosCreator中使用JSZip壓縮

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

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

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

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

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

    Bootstrap按鈕組件詳解

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

最新評論