真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何解決php上傳多張圖片時,選擇圖片后即可預覽的問題

本篇文章給大家分享的是有關(guān)如何解決php上傳多張圖片時,選擇圖片后即可預覽的問題,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

成都創(chuàng)新互聯(lián)公司是一家集網(wǎng)站建設,資陽企業(yè)網(wǎng)站建設,資陽品牌網(wǎng)站建設,網(wǎng)站定制,資陽網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,資陽網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

這幾天一直在解決一個問題,上傳圖片時選擇成功后就能預覽。

如何解決php上傳多張圖片時,選擇圖片后即可預覽的問題

需求:在點擊上傳圖標的時候會在前面的input框中顯示出文件名,然后點擊后面的查看按鈕就可以預覽選擇的這張圖片了,要求不能刷新頁面

1.一開始的時候打算用ajax上傳,后來發(fā)現(xiàn)多張圖片一同上傳的時候會出現(xiàn)問題,ajax上傳圖片的原理是當你選中一張圖片的時候會使用js在這個type為file的input的框外面包上一個form表單然后通過ajaxSubmit自動提交到php文件,之后通過php文件進行上傳,最后返回一個上傳到服務器的圖片路徑,點擊查看的時候就可以獲取到這個圖片,實際上這個時候圖片已經(jīng)上傳到服務器了。但這個需求是多張圖片,這么做會出現(xiàn)很大的問題。

2.之后在網(wǎng)上查到了使用js實時預覽本地選中的圖片,這個和ajax上傳的不同就是,在選擇完圖片文件之后并不會上傳到服務器,而是直接調(diào)取本機圖片的路徑預覽。下面就是用這種方法實現(xiàn)最終效果的例子。

方法:


首先需要一個上傳文件的input的框

然后在下面加一個獲取它的本地圖片路徑的隱藏形式的input的框

//圖片上傳預覽    IE是用了濾鏡。
        function previewImage(file)
        {
            if (file.files && file.files[0])
            {
                var reader = new FileReader();
                reader.onload = function(evt){
                    $(file).next().val(evt.target.result);
                }
                reader.readAsDataURL(file.files[0]);
            }
            else //兼容IE
            {
                var sFilter='filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale,src="';
                file.select();
                var src = document.selection.createRange().text;
                //p.innerHTML = '';
                //var img = document.getElementById('imghead');
                //img.filters.item('DXImageTransform.Microsoft.AlphaImageLoader').src = src;
                $(this).next().val(src);
                //var rect = clacImgZoomParam(MAXWIDTH, MAXHEIGHT, img.offsetWidth, img.offsetHeight);
                //status =('rect:'+rect.top+','+rect.left+','+rect.width+','+rect.height);
                //p.innerHTML = "

"; } } function clacImgZoomParam( maxWidth, maxHeight, width, height ){ var param = {top:0, left:0, width:width, height:height}; if( width>maxWidth || height>maxHeight ) { rateWidth = width / maxWidth; rateHeight = height / maxHeight; if( rateWidth > rateHeight ) { param.width = maxWidth; param.height = Math.round(height / rateWidth); }else { param.width = Math.round(width / rateHeight); param.height = maxHeight; } } param.left = Math.round((maxWidth - param.width) / 2); param.top = Math.round((maxHeight - param.height) / 2); return param; }

可以看到在選擇圖片的時候調(diào)用了previewImage()方法,使用這個方法獲取了本機圖片的地址傳入到class為imageurl的input框中。

之后是創(chuàng)建一個查看按鈕,我是在

下面直接加了一個按鈕,當點擊這個按鈕的時候獲取$(this).prev().val(),然后傳給想要顯示圖片的p中的img里,這樣圖片就顯示出來了

經(jīng)過測試這個方法可以滿足firefox,chrome,ie10以上,基本上已經(jīng)夠用了吧。

壓了幾天得問題沒想到就這么解決了,效率不高,積累經(jīng)驗!積累經(jīng)驗!積累經(jīng)驗!

以上就是如何解決php上傳多張圖片時,選擇圖片后即可預覽的問題,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


文章題目:如何解決php上傳多張圖片時,選擇圖片后即可預覽的問題
路徑分享:http://weahome.cn/article/jhdjjd.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部