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

localResizeIMG先壓縮后使用ajax無刷新上傳(移動端)

 更新時間:2015年08月11日 14:33:56   作者:碼農(nóng)小兵  
隨著技術(shù)的發(fā)展,移動設(shè)備像素越來越高,但是這么大的圖片怎么上傳呢?下面小編就給大家一起學(xué)習(xí)移動端圖片上傳的方法之localResizeIMG先壓縮后使用ajax無刷新上傳,需要的朋友可以參考下

下面通過文字說明和代碼分析的方式給大家分享移動端圖片上傳之localResizeIMG先壓縮后ajax無刷新上傳,具體實現(xiàn)過程請看下文。

現(xiàn)在科技太發(fā)達(dá),移動設(shè)備像素越來越高,隨便一張照片2M+,但是要做移動端圖片上傳和pc上略有不同,移動端你不能去限制圖片大小,讓用戶先處理圖片再上傳,這樣不現(xiàn)實。所以理解的解決方案就是在上傳先進(jìn)行圖片壓縮,然后再把壓縮后的圖片上傳到服務(wù)器。

一翻google之后,發(fā)現(xiàn)了localResizeIMG,它會對圖片進(jìn)行壓縮成你指定寬度及質(zhì)量度并轉(zhuǎn)換成base64圖片格式,那么我們就可以把這個base64通過ajax傳到后臺,再進(jìn)行保存,先壓縮后上傳的目的就達(dá)到了。

處理過程

LocalResizeIMG壓縮圖片
AjaxPost圖片base64到后臺
后臺接收base64并保存,返回狀態(tài)
前臺代碼

重點,引用LocalResizeIMG.js(插件主體)及mobileBUGFix.mini.js(移動端的補(bǔ)?。?/strong>

<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8">
<title>移動端圖片上傳解決方案localResizeIMG先壓縮后ajax無刷新上傳</title>
<meta name="description" content="" />
<meta name="viewport" content="width=device-width , initial-scale=1.0 , user-scalable=0 , minimum-scale=1.0 , maximum-scale=1.0" />
<script type='text/javascript' src='js/jquery-2.0.3.min.js'></script>
<script type='text/javascript' src='js/LocalResizeIMG.js'></script>
<script type='text/javascript' src='js/patch/mobileBUGFix.mini.js'></script>
<style type="text/css">
 body{font-family:"微軟雅黑"}
 .uploadbtn{ display:block;height:40px; line-height:40px; color:#333; text-align:center; width:100%; background:#f2f2f2; text-decoration:none; }
 .imglist{min-height:200px;margin:10px;}
 .imglist img{width:100%;}
</style>
</head>
<body>
<div style="width:500px;margin:10px auto; border:solid 1px #ddd; overflow:hidden; ">
 <input type="file" id="uploadphoto" name="uploadfile" value="請點擊上傳圖片" style="display:none;" /> 
 <div class="imglist"></div> 
 <a href="javascript:void(0);" onclick="uploadphoto.click()" class="uploadbtn">點擊上傳文件</a>
</div>
<div style="text-align:center;margin-top:50px;">@ <a >碼農(nóng)小兵,專注web開發(fā) 歡迎投稿</a></div> 
</body>
</html>

Js部份,localResizeIMG及Ajax提交部份

使用方法

$('input:file').localResizeIMG({
   width: 400,//寬度
   quality: 1,//質(zhì)量
   success: function (result) {
      result.base64/result.clearBase64
   }
});

localResizeIMG參數(shù):

          width:縮略圖寬度
          quality:圖片質(zhì)量,0—1,越大越好

localResizeIMG返回值

           result.base64:帶圖片類型的base64編碼,可直接用于img標(biāo)簽的src,如“data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/…2wBDAAYEBQYFBAY”;

           result.clearBase64:不帶圖片類型的編碼,如“/9j/4AAQSkZJRgABAQAAAQABAAD/…2wBDAAYEBQYFBAY”

$(document).ready(function(e) {
  $('#uploadphoto').localResizeIMG({
   width: 400,
   quality: 1,
   success: function (result) { 
     var submitData={
        base64_string:result.clearBase64, 
      }; 
    $.ajax({
      type: "POST",
      url: "upload.php",
      data: submitData,
      dataType:"json",
      success: function(data){
       if (0 == data.status) {
        alert(data.content);
        return false;
       }else{
        alert(data.content);
        var attstr= '<img src="'+data.url+'" alt="" />'; 
        $(".imglist").append(attstr); 
       }
      }, 
      complete :function(XMLHttpRequest, textStatus){
      },
      error:function(XMLHttpRequest, textStatus, errorThrown){ //上傳失敗 
        alert(XMLHttpRequest.status);
        alert(XMLHttpRequest.readyState);
        alert(textStatus);
      }
    }); 
   }
 });
});

保存文件

       在上面一步中,我們把result.clearBase64通過Ajax傳入到upload.php中,接下來我們就要在upload.php中接收base64參數(shù),把它轉(zhuǎn)換成img文件保存來服務(wù)器中,并給出提示。

$base64_string = $_POST['base64_string'];
 $savename = uniqid().'.jpeg';//localResizeIMG壓縮后的圖片都是jpeg格式
 $savepath = 'images/'.$savename; 
 $image = base64_to_img( $base64_string, $savepath );
 if($image){
   echo '{"status":1,"content":"上傳成功","url":"'.$image.'"}';
 }else{
   echo '{"status":0,"content":"上傳失敗"}';
 } 
 function base64_to_img( $base64_string, $output_file ) {
   $ifp = fopen( $output_file, "wb" ); 
   fwrite( $ifp, base64_decode( $base64_string) ); 
   fclose( $ifp ); 
   return( $output_file ); 
 }

不足之處

        localResizeIMG壓縮后的圖片模式都是jpeg,不能保證原有格式。

        當(dāng)圖片寬度小于localResizeIMG設(shè)置的width參數(shù)時,圖片會被拉申,從而引起圖片失真(比如width高為600,圖片只在400px時,壓縮后的圖片就變成了600px,圖片尺寸變大了,會失真),不知道大家有沒有什么好的解決方法。

以上內(nèi)容是本文介紹localResizeIMG先壓縮后使用ajax無刷新上傳的全部內(nèi)容,希望大家喜歡。

相關(guān)文章

  • JavaScript用20行代碼實現(xiàn)虎年春節(jié)倒計時

    JavaScript用20行代碼實現(xiàn)虎年春節(jié)倒計時

    春節(jié)將至,相信大家跟小編一樣很激動呀。為了迎接虎年春節(jié)到來,小編為大家準(zhǔn)備了一個虎年春節(jié)倒計時,僅20行代碼用js就實現(xiàn)啦。感興趣的可以動手試一試
    2022-01-01
  • JavaScript實現(xiàn)圖像模糊化的方法實例

    JavaScript實現(xiàn)圖像模糊化的方法實例

    這篇文章主要介紹了JavaScript實現(xiàn)圖像模糊化的方法,文中先進(jìn)行簡單介紹,而后給出了完整的實例代碼,有需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-01-01
  • js實現(xiàn)連個數(shù)字相加而不是拼接的方法

    js實現(xiàn)連個數(shù)字相加而不是拼接的方法

    這篇文章主要介紹了js如何實現(xiàn)連個數(shù)字相加而不是拼接,需要的朋友可以參考下
    2014-02-02
  • js 判斷checkbox是否選中的實現(xiàn)代碼

    js 判斷checkbox是否選中的實現(xiàn)代碼

    大家在很多場合也許會遇到判斷頁面是否有元素選中,下面介紹的是利用js判斷是否選中CheckBox的方法。
    2010-11-11
  • 手把手教你實現(xiàn)一個JavaScript時間軸組件

    手把手教你實現(xiàn)一個JavaScript時間軸組件

    本文主要是給大家?guī)硪粋€時間軸的組件開發(fā)教程,其主要功能就是可以拖動時間軸來定位當(dāng)前時間,可以通過鼠標(biāo)滾輪來修改當(dāng)前時間分辨率,需要的可以參考一下
    2022-10-10
  • JS正則子匹配實例分析

    JS正則子匹配實例分析

    這篇文章主要介紹了JS正則子匹配用法,結(jié)合簡單實例形式分析了js正則字匹配的概念、用法與相關(guān)注意事項,需要的朋友可以參考下
    2016-12-12
  • JavaScript位置參數(shù)實現(xiàn)原理及過程解析

    JavaScript位置參數(shù)實現(xiàn)原理及過程解析

    這篇文章主要介紹了JavaScript位置參數(shù)實現(xiàn)原理及過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-09-09
  • js html實現(xiàn)計算器功能

    js html實現(xiàn)計算器功能

    這篇文章主要為大家詳細(xì)介紹了js html實現(xiàn)計算器功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • JS獲取iframe中l(wèi)ongdesc屬性的方法

    JS獲取iframe中l(wèi)ongdesc屬性的方法

    這篇文章主要介紹了JS獲取iframe中l(wèi)ongdesc屬性的方法,實例分析了longdesc屬性的功能及相關(guān)的獲取技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-04-04
  • js+html5實現(xiàn)canvas繪制網(wǎng)頁時鐘的方法

    js+html5實現(xiàn)canvas繪制網(wǎng)頁時鐘的方法

    這篇文章主要介紹了js+html5實現(xiàn)canvas繪制網(wǎng)頁時鐘的方法,涉及html5圖形繪制的基礎(chǔ)技巧,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-05-05

最新評論