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

首頁 > 編程 > HTML > 正文

Html5實現單張、多張圖片上傳功能

2024-08-26 00:21:26
字體:
來源:轉載
供稿:網友

前言

今天我們聊一聊圖片上傳,單張Or多張 ,如今,各大圖片上傳插件數不勝數,例如:Jquery的 verupload.js,jQuery File Upload、Uploadify、jQuery.filter等等。But。上面說到的這些插件,今天我們不談,我們來看一看使用HTML5中的FileReader 如何實現 圖片的單張及多張預覽、刪除、上傳等功能。先看下實現后的效果如下:

Html5,圖片上傳

2|0實現

2|1前端部分

這塊是用戶點擊按鈕 其中我們最重要的一句話是input type=file 和給了一個multiple屬性,可以滿足多張圖片上傳

<div class="form-group form-row">        <label class="col-sm-2 control-label uText">俱樂部相冊</label><div class="row">                        <div class="col-xs-10 col-sm-8 mTop5">                            <label                                <input type="file" accept="image/*" name="ClubImagesUpload" id="ClubImagesUpload" class="hide" multiple="multiple">                                <img src="/Images/registerNewSite/btn_addimg.png" class="addImg"/>                            </label>                        </div>                    </div></div>

下面這塊區域是用于圖片預覽的

<div class="form-group form-row" id="preViewMore"><div class="row">      <div class="col-xs-9">         <div id="clubInputImagePreview" class="col-sm-9 img-preview img-preview-sm"></div>       </div>  </div></div>

2|2樣式部分

什么?連樣式你都要看,還有沒有人性(苦笑臉)

2|3Js部分

首先我們分析下上面的html,我們用一個label把input和一個img標簽包起來了,我們希望點擊效果圖那個+號圖片,就能彈出選擇相片的對話框,所以,我們需要先給label來一個點擊事件:

$("#btnClubImg").click(function() {    //TODO Something});

接著我們再看,因為我們是要獲取上傳的文件,而我們的文件主要是在input上,所以,我們先將input標簽獲取到:

$("#btnClubImg").click(function() {      var $input = $("#ClubImagesUpload");     console.log($input);//打印當前元素});

我們將當前input元素標簽打印出來看看是個什么東東

Html5,圖片上傳

我們展開第一項會發現files里面length長度是0

Html5,圖片上傳

好,我們繼續分析,因為我們想要能當input框改變的時候,說簡單點 就是有選擇到文件的時候,我們能獲取到當前選擇的文件,這個和獲取input框文字輸入是一樣的道理,所以,經過分析,我們知道需要給input標簽加一個change事件:

 $("#btnClubImg").click(function() {      var $input = $("#ClubImagesUpload");      console.log($input);      $input.on("change", function () {         console.log(this);//打印改變后的當前元素  });});   

讓我們來瞄一眼,獲取到改變后的input元素里面有些啥東東:

Html5,圖片上傳

這里很清楚得可以看到,我們獲取到了選擇的圖片,包括有最后修改事件,圖片名稱,大小以及圖片類型(有了文件類型,我們就可以判斷當前用戶選擇的是否是圖片不是嗎(斜眼笑)) 同樣,這是單個文件的, 如果是多個文件,就會有多個file

Html5,圖片上傳

接著往下看,通過打印輸出我們可以看到,我們再input 標簽的files元素上已經拿到了我們想要的文件信息,我們只需要獲取它們就行了:

 var files = this.files; var length = files.length;

這樣,我們就可以獲取到所有文件,以及文件的個數,那這里問題來了,我們如果是選擇多個文件,如果將其依次輸出并展示到頁面上呢?看到上面標注的四個字,腦袋中有沒有閃現出兩個字呢?循環

 $.each(files, function (key, value) {        //TOTO Something  });

通過將上面得到的files 循環,我們可以依次得到每個文件的信息。這樣,你就不僅可以將其依次輸出,如果你愿意,你還可以將其送上天~

var fileReader = new FileReader();//實例化一個FileReader對象var file_ = files[key];//獲取當前文件if (/^image///w+$/.test(file_.type)) {//將當前文件進行正則匹配,看是否是選擇的圖片      fileReader.onload = function() {//當讀取操作完成時調用       }         } 

有必要延伸下FileReader的知識點:

FileReader主要用于將文件內容讀入內存,通過一系列異步接口,可以在主線程中訪問本地文件。

使用FileReader對象,web應用程序可以異步的讀取存儲在用戶計算機上的文件(或者原始數據緩沖)內容,可以使用File對象或者Blob對象來指定所要處理的文件或數據。

Html5,圖片上傳

回到主題,我們已經能夠得到文件并且得到返回,所以此時,我們只需要展示返回的結果就行了

$("#clubInputImagePreview").css("background-image", "url(" + this.result + ")");

我們將其this.result打印出來看看是個什么東東:

Html5,圖片上傳

不言而喻,是將圖片轉換成了Base64的數據格式。最后,我們調用 readAsDataURL 讀取文件內容,將其用data:url字符串表示出來

fileReader.readAsDataURL(value);

這樣,你就可以得到一個簡易的圖片上傳的Demo了,但是并不是最終的,因為你還需要加很多業務進去。比如:得到一張預覽圖片后,當前標簽會被占用,如果下次循環進來,直接使用原標簽,肯定會將之前的圖片替換,那這肯定不是我們想要的效果,我們希望是能依次展示,而不是替換展示。所以,我們還需要做一些處理:

 $("#clubInputImagePreview").css("background-image", "url(" + this.result + ")");//使用apend再當前元素下追加一個子節點 $("#clubInputImagePreview") .append("<img src='/Images/registerNewSite/btn_r_del.png' class='clubsImage'  id='ImgRemove' />");//使用after 向當前兄弟節點 追加一個同級節點                                       $("#clubInputImagePreview").after( "<div id='clubInputImagePreview1' class='col-sm-9 img-preview img-preview-sm delImg' ></div>");

然后我們追加的刪除圖片,也需要給其點擊事件,讓我們的當前預覽區域消失:

$("#ImgRemove").click(function () {          $(this).parent().remove();});

最后,你會發現結果還不是我們想要的,那是因為 當前ID還在,所以無法進行下一步操作,而我們只需要將當前元素的Id Remove掉,然后新增一個同ID的元素,這樣瀏覽器就會認為這是一個新的元素:

 $input.removeAttr("id"); var newInput ='<input type="file" accept="image/*" name="ClubImagesUpload" id="ClubImagesUpload" class="hide" multiple="multiple">'; $(this).append($(newInput));

最后完整JS代碼如下:

  var intP = 0;        $("#btnClubImg").click(function() {            var $input = $("#ClubImagesUpload");//            console.log($input);            $input.on("change",                function () {//                    console.log(this);                    var files = this.files;                    var length = files.length;                    if (intP > 8) {                        layer.msg('圖片不能再多了~', {});                        return;                    }                    $.each(files,                        function (key, value) {                            var fileReader = new FileReader();                            var file_ = files[key];                            if (/^image///w+$/.test(file_.type)) {                                fileReader.onload = function() {                                    if (intP > 8) {                                        layer.msg('圖片不能再多了~', {});                                        return;                                    }                                    if (key == 0 && intP == 0) {                                        console.log(this.result);                                        $("#clubInputImagePreview").css("background-image", "url(" + this.result + ")");                                        $("#clubInputImagePreview")                                            .append(                                            "<img src='/Images/registerNewSite/btn_r_del.png' class='clubsImage'  id='ImgRemove' />");                                        $("#clubInputImagePreview").after(                                            "<div id='clubInputImagePreview1' class='col-sm-9 img-preview img-preview-sm delImg'></div>");                                    } else {                                        $("#clubInputImagePreview" + parseInt(intP) + "").css("background-image",                                            "url(" + this.result + ")");                                        $("#clubInputImagePreview" + parseInt(intP) + "").append(                                            "<img src='/Images/registerNewSite/btn_r_del.png' class='clubsImage'  id='ImgRemove" +                                            parseInt(parseInt(1) + parseInt(intP)) +"' />");                                        $("#clubInputImagePreview" + parseInt(intP) + "").after(                                            "<div id='clubInputImagePreview" +                                            parseInt(parseInt(1) + parseInt(intP)) +                                            "'class='col-sm-9 img-preview img-preview-sm delImg' ></div>");                                    }                                    if (key == 0 && intP == 0) {                                        $("#ImgRemove").click(function () {                                            $(this).parent().remove();                                        });                                    } else {                                        $("#ImgRemove" + parseInt(parseInt(1) + parseInt(intP)) + "").click(function () {                                            $(this).parent().remove();                                        });                                    }                                    intP += parseInt(1);                                };                                fileReader.readAsDataURL(value);                            } else {                                layer.msg("格式錯誤<br/>請選擇一個圖片文件");                            }                        });                });            $input.removeAttr("id");            var newInput =                '<input type="file" accept="image/*" name="ClubImagesUpload" id="ClubImagesUpload" class="hide" multiple="multiple">';            $(this).append($(newInput));        });

總結

以上所述是小編給大家介紹的Html5實現單張、多張圖片上傳功能,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩激情视频| 欧美性视频网站| 午夜剧场成人观在线视频免费观看| 亚洲精品在线不卡| 国产97免费视| 一区二区三区天堂av| 久久国产精品久久久久久久久久| 亚洲激情在线观看视频免费| 成人午夜在线视频一区| 亚洲免费伊人电影在线观看av| 久久天天躁狠狠躁夜夜爽蜜月| 国产亚洲精品久久久久动| 日韩免费av片在线观看| 中文字幕免费精品一区高清| 91大神在线播放精品| 欧美精品一本久久男人的天堂| 亚洲欧美国产一本综合首页| 在线精品视频视频中文字幕| 国产精品第10页| 国产成人综合久久| 亚洲成人1234| 欧美国产日韩二区| 6080yy精品一区二区三区| 蜜臀久久99精品久久久久久宅男| 97视频在线播放| 日韩成人在线视频观看| 黑人巨大精品欧美一区二区| 欲色天天网综合久久| 91精品国产乱码久久久久久蜜臀| 久久天天躁狠狠躁夜夜躁| 96pao国产成视频永久免费| 亚洲精品美女在线观看播放| 国产在线98福利播放视频| 国产综合色香蕉精品| 亚洲无av在线中文字幕| 日韩欧美亚洲国产一区| 91精品国产成人| 久久视频在线播放| 国产精品一二区| 成人网中文字幕| 亚洲电影在线观看| 久久综合色影院| 青青草99啪国产免费| 成人精品一区二区三区电影免费| 日韩精品在线观看一区二区| 欧美性猛交xxxx乱大交蜜桃| 91精品国产色综合久久不卡98| 综合136福利视频在线| 亚洲第一网站男人都懂| 欧美xxxx做受欧美| 亚洲欧美日本精品| 国产精品91在线观看| 日韩亚洲精品电影| 亚洲自拍高清视频网站| 色七七影院综合| 欧美日韩中国免费专区在线看| 97香蕉超级碰碰久久免费软件| 一个人看的www欧美| 久久国产精品久久久| 亚洲精选在线观看| 青青精品视频播放| 一区二区三区视频免费在线观看| 日韩视频在线一区| 热久久美女精品天天吊色| 欧美性猛交xxxx富婆弯腰| www国产亚洲精品久久网站| 色婷婷av一区二区三区在线观看| 欧美性xxxxxxx| 97在线免费观看| 亚洲综合在线播放| 日韩视频第一页| 亚洲视频999| 欧美美女操人视频| 国产精品国产自产拍高清av水多| 一区二区三区视频观看| 日韩精品久久久久| 国产69精品久久久久9| 少妇久久久久久| 亚洲视频在线观看免费| 欧美精品videosex性欧美| 91九色视频导航| 国产xxx69麻豆国语对白| 国产午夜精品全部视频在线播放| 久久97精品久久久久久久不卡| 日本精品久久久久久久| 国产精品精品一区二区三区午夜版| 国产精品第1页| 日韩美女av在线| 日本久久精品视频| 午夜精品国产精品大乳美女| 国产精品午夜一区二区欲梦| 欧美重口另类videos人妖| 在线观看日韩专区| 亚洲精品成人av| 中文字幕精品www乱入免费视频| 欧美福利视频在线| 日本久久久久久久| 97久久精品视频| 有码中文亚洲精品| 亚洲精品乱码久久久久久按摩观| 精品女厕一区二区三区| 最好看的2019年中文视频| 91视频免费网站| 久热在线中文字幕色999舞| 九九热这里只有在线精品视| 亚洲欧美日韩天堂一区二区| 国产在线精品成人一区二区三区| 亚洲无av在线中文字幕| 日韩欧美在线网址| 亚洲一区亚洲二区| 国模视频一区二区三区| 精品国产电影一区| 亚洲一区二区三区在线视频| 成人福利在线观看| 久久成人国产精品| 国内精品久久久久伊人av| 国产精品精品一区二区三区午夜版| 亚洲成色777777女色窝| 亚洲美女精品成人在线视频| 久久久久久国产精品久久| 国产脚交av在线一区二区| 亚洲国产精品久久久久久| 欧美日韩国内自拍| 国产精品99导航| 欧美国产极速在线| 亚洲激情自拍图| 亚洲欧洲在线播放| 在线精品高清中文字幕| 日韩在线视频免费观看高清中文| 亚洲在线观看视频| 亚洲成人国产精品| 国产成人极品视频| 国产精品成人国产乱一区| 亚洲人成人99网站| 九九热这里只有精品6| 亚洲二区在线播放视频| 成人免费视频a| 91视频国产精品| 久久国产精品影视| 中文字幕亚洲精品| 国产欧美日韩亚洲精品| 欧美诱惑福利视频| 456国产精品| 欧美性猛交xxxx乱大交3| 久久亚洲精品视频| 亚洲天堂精品在线| 国产视频精品va久久久久久| 国产精品美女www| 日韩乱码在线视频| 91精品国产综合久久男男| 精品久久久久久久久中文字幕| 日韩在线视频免费观看高清中文| 国产精品爱啪在线线免费观看| 色一区av在线| 色综合天天综合网国产成人网| 亚洲欧美自拍一区| 在线观看亚洲视频| 久久久久久亚洲| 精品人伦一区二区三区蜜桃免费| 8x拔播拔播x8国产精品| 国产精品久久久av| 欧美中文在线视频| 久久91亚洲精品中文字幕奶水| 庆余年2免费日韩剧观看大牛|