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

首頁 > 編程 > JavaScript > 正文

如何用input標簽和jquery實現多圖片的上傳和回顯功能

2019-11-19 13:50:26
字體:
來源:轉載
供稿:網友

本文主要記錄如何用input標簽和jquery實現多圖片的上傳和回顯,不會涉及后端的交互,大概的效果看圖

 

效果圖

我們從零來做一個這樣的demo

第一步:

我們先完善一下我們的頁面,默認的input-file標簽非常丑,我們美化一下它,不會的可以百度一下,就是外面套個盒子,設置input的opacity為0,然后外面的盒子設計成我們喜歡的樣式即可,我就隨便做了一下。

 

大概的樣式

還是放一下源碼,只談效果,不放源碼的都是耍流氓

這是body

<body>  <div class="uploadImgBtn" id="uploadImgBtn">    <input class="uploadImg" type="file" name="file" multiple id="file">  </div></body>

這是css的樣式

.uploadImgBtn {    width: 100px;    height: 100px;    cursor: pointer;    position: relative;    background: url("img/plus.png") no-repeat;    -webkit-background-size: cover;    background-size: cover;  }  .uploadImgBtn .uploadImg {    position: absolute;    right: 0;    top:0;    width: 100%;    height: 100%;    opacity: 0;    cursor: pointer;  }  //這是一個用做回顯的盒子的樣式  .pic{    width: 100px;    height: 100px;  }  .pic img {    width: 100%;    height: 100%;  }

代碼的量并沒有多少,接下來我們就分析一下如何讓圖片回顯;我知道有兩種方式,一種是先上傳到服務器,并返回該圖片的url,然后渲染在頁面中;另一種呢,是利用h5的FileReader對象直接在本地預覽圖片,用戶確認后再上傳服務器。

我們是采用第二種形式,既然知道了思路那就開始編程吧

<script>  $(document).ready(function(){    //為外面的盒子綁定一個點擊事件    $("#uploadImgBtn").click(function(){      /*      1、先獲取input標簽      2、給input標簽綁定change事件      3、把圖片回顯       *///      1、先回去input標簽      var $input = $("#file");//      2、給input標簽綁定change事件      $input.on("change" , function(){        //補充說明:因為我們給input標簽設置multiple屬性,因此一次可以上傳多個文件        //獲取選擇圖片的個數        var files = this.files;        var length = files.length;        console.log("選擇了"+length+"張圖片");        //3、回顯        for( var i = 0 ; i < length ; i++ ){          var fr = new FileReader(),            div = document.createElement("div"),            img = document.createElement("img");          div.className = 'pic';          fr.onload = function(e){            console.log("回顯了圖片")            img.src = this.result;            div.appendChild(img)            document.body.appendChild(div);          }          fr.readAsDataURL(files[i]);//讀取文件        }      })    })  })</script>

代碼的思路也可以說是很簡單,先給外面的盒子綁定點擊事件,然后獲取input標簽,給input標簽綁定change事件,然后用一個for循環把獲得的數據回顯出來,for循環里有一個異步事件onload是用來渲染圖片,來我們看看效果圖

 

效果圖

我們選擇了三張圖片,卻顯示了一張,話說我們在for循環里創建了三個div和img卻只顯示了一張圖片,這里面肯定有蹊蹺。

我們來仔細分析一下,前面我已經說了,回顯的for循環里面有一個異步事件,既然是異步的,可能for循環執行完了,才執行onload事件使我們設置的下標i值和預期的結果不一致;那我們如何解決呢,如果我們能形成一個函數作用域,在里面每次回顯一張圖片,我覺得我們就可能解決了。我們來嘗試一下,我們前端可以使用jquery的each方案,它自帶回調函數,形成了函數作用域。我們看一下代碼

<script>  $(document).ready(function(){    //為外面的盒子綁定一個點擊事件    $("#uploadImgBtn").click(function(){      /*      1、先獲取input標簽      2、給input標簽綁定change事件      3、把圖片回顯       *///      1、先回去input標簽      var $input = $("#file");//      2、給input標簽綁定change事件      $input.on("change" , function(){        //補充說明:因為我們給input標簽設置multiple屬性,因此一次可以上傳多個文件        //獲取選擇圖片的個數        var files = this.files;        var length = files.length;        console.log("選擇了"+length+"張圖片");        //3、回顯        $.each(files,function(key,value){          //每次都只會遍歷一個圖片數據          var div = document.createElement("div"),            img = document.createElement("img");          div.className = "pic";          var fr = new FileReader();          fr.onload = function(){            img.src=this.result;            div.appendChild(img);            document.body.appendChild(div);          }          fr.readAsDataURL(value);        })      })    })  })</script>

在看一下運行的效果

 

效果圖

這回就達到了我們的預期效果。這就結束了嗎,肯定不是的,當我們再次點擊上傳圖片按鈕,肯定會把上一次的結果給覆蓋掉,那當我們跑業務的時候,這肯定不是我們想要看到的,那我們如何解決這個問題呢,那肯定是用多個input標簽啊,那我們怎么能保證我們點擊的時候就是新加的那個input標簽呢,我的解決方案是這樣的,我們把上一次的input標簽的id屬性清除掉,為我們新生成的input標簽加上這個屬性,因為我們是通過id綁定事件的,所以我們就可以為我們新生成的input標簽綁定事件了,而原來的input標簽因為沒有了id屬性,而不被選中,我們來看代碼

<script>  $(document).ready(function(){    //為外面的盒子綁定一個點擊事件    $("#uploadImgBtn").click(function(){      /*      1、先獲取input標簽      2、給input標簽綁定change事件      3、把圖片回顯       *///      1、先回去input標簽      var $input = $("#file");      console.log($input)//      2、給input標簽綁定change事件      $input.on("change" , function(){        console.log(this)        //補充說明:因為我們給input標簽設置multiple屬性,因此一次可以上傳多個文件        //獲取選擇圖片的個數        var files = this.files;        var length = files.length;        console.log("選擇了"+length+"張圖片");        //3、回顯        $.each(files,function(key,value){          //每次都只會遍歷一個圖片數據          var div = document.createElement("div"),            img = document.createElement("img");          div.className = "pic";          var fr = new FileReader();          fr.onload = function(){            img.src=this.result;            div.appendChild(img);            document.body.appendChild(div);          }          fr.readAsDataURL(value);        })      })      //4、我們把當前input標簽的id屬性remove      $input.removeAttr("id");      //我們做個標記,再class中再添加一個類名就叫test      var newInput = '<input class="uploadImg test" type="file" name="file" multiple id="file">';      $(this).append($(newInput));    })  })</script>

 

效果圖

總結

以上所述是小編給大家介紹的如何用input標簽和jquery實現多圖片的上傳和回顯功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产999| 中文字幕亚洲欧美日韩在线不卡| 欧美在线xxx| 久久男人资源视频| 欧美色欧美亚洲高清在线视频| 精品福利视频导航| 日韩av电影中文字幕| 日韩激情av在线播放| 欧美精品videossex88| 亚洲精品自产拍| 欧美视频在线免费看| 国产69久久精品成人看| 欧美午夜精品久久久久久浪潮| 国产精品视频网站| 亚洲精品国产电影| 懂色av一区二区三区| 5252色成人免费视频| 亚洲毛片在线观看| 久久影视电视剧免费网站| 国产精品69精品一区二区三区| 欧美成人合集magnet| 日日狠狠久久偷偷四色综合免费| 亚洲国产精品久久91精品| 亚洲精品一区中文| 日韩中文在线观看| 日韩女优在线播放| 欧美日韩免费区域视频在线观看| 国产精品日韩久久久久| 成人精品久久一区二区三区| 欧美亚洲第一页| 精品中文字幕久久久久久| 国产激情久久久久| 日韩在线视频一区| 超碰日本道色综合久久综合| 日韩电影免费观看中文字幕| 91tv亚洲精品香蕉国产一区7ujn| 精品国产91久久久| 久久夜色精品国产欧美乱| 国产在线高清精品| 日韩视频一区在线| 国产不卡一区二区在线播放| 亲子乱一区二区三区电影| 久久精品国产69国产精品亚洲| 日韩精品在线观看视频| 中文字幕视频在线免费欧美日韩综合在线看| 日韩av在线导航| 亚洲精品黄网在线观看| 亚洲人成电影网站色www| 国产成人精品日本亚洲专区61| 欧美日韩国产精品一区二区不卡中文| 日韩av三级在线观看| 日韩美女毛茸茸| 亚洲直播在线一区| 久久精品成人一区二区三区| 国产精品亚洲网站| 欧美精品激情在线观看| 成人国内精品久久久久一区| 久久精品国产视频| 久久精品国产免费观看| 亚洲国产精品热久久| 欧美日韩中文字幕| 欧美成年人视频网站| 亚洲欧美精品伊人久久| 精品国偷自产在线视频99| 日本国产一区二区三区| 欧美性69xxxx肥| 久久偷看各类女兵18女厕嘘嘘| 中文字幕久热精品视频在线| 欧美裸体xxxx极品少妇| 日韩欧美主播在线| 亚洲91精品在线观看| 国内精品伊人久久| 亚洲第一精品夜夜躁人人爽| 亚洲第一精品夜夜躁人人爽| 北条麻妃99精品青青久久| 国产亚洲精品综合一区91| 91亚洲精品一区二区| 国产精品入口尤物| 国内免费精品永久在线视频| 色综合久久精品亚洲国产| 国产精品自产拍高潮在线观看| 亚洲欧美激情四射在线日| 亚洲成人久久电影| 亚洲国产99精品国自产| 亚洲欧美一区二区激情| 国产精品久久77777| 性欧美视频videos6一9| 日韩精品视频免费在线观看| 亚洲精选一区二区| 亚洲欧美日韩精品久久奇米色影视| 日韩欧美亚洲综合| 亚洲人成伊人成综合网久久久| 欧美日韩国产中文精品字幕自在自线| 97国产精品久久| 最近免费中文字幕视频2019| 中文字幕日韩高清| 亚洲天堂网站在线观看视频| 成人免费xxxxx在线观看| 日日噜噜噜夜夜爽亚洲精品| 国产精品福利久久久| 久久手机精品视频| 日韩麻豆第一页| 日韩专区在线播放| 国产一区二区欧美日韩| 国产精品成人免费视频| 国产精品久久9| 欧美日韩人人澡狠狠躁视频| 日韩欧美在线免费观看| 欧美精品免费看| 欧美日韩国产成人高清视频| 精品久久香蕉国产线看观看gif| 亚洲偷熟乱区亚洲香蕉av| xxx一区二区| 亚洲午夜精品久久久久久性色| 美女扒开尿口让男人操亚洲视频网站| 97精品欧美一区二区三区| 最好看的2019年中文视频| 成人国产精品日本在线| 深夜福利一区二区| 精品福利视频导航| 九九热最新视频//这里只有精品| 国产日韩中文字幕在线| 97国产在线观看| 国产视频久久久久| 九九热这里只有精品6| 日产精品99久久久久久| 国产丝袜精品第一页| 国产视频久久久久| 国产女精品视频网站免费| 亚洲精品天天看| 欧美色视频日本版| 欧美一区三区三区高中清蜜桃| 精品国产老师黑色丝袜高跟鞋| 国产拍精品一二三| 亚洲国产精彩中文乱码av在线播放| 日韩免费在线免费观看| 97精品一区二区三区| 成人羞羞国产免费| 中文字幕久热精品在线视频| 国产综合久久久久久| 亚洲成人av资源网| 97精品国产91久久久久久| 欧美亚洲另类制服自拍| 国产做受69高潮| 欧美成人免费全部| 在线观看国产精品91| 亚洲一区二区三区四区在线播放| 精品综合久久久久久97| 亚洲天堂成人在线| 91综合免费在线| 高清视频欧美一级| 在线观看亚洲视频| 91久久夜色精品国产网站| 亚洲人成绝费网站色www| 欧洲成人免费视频| 在线观看亚洲视频| 久久伊人精品视频| 久久99热这里只有精品国产| 国产精品亚洲美女av网站| 91久久精品美女高潮| 欧美在线免费观看| 97超碰色婷婷| 亚洲自拍在线观看| 国产成人久久久精品一区|