javascript實現圖片上傳前台頁面_javascript技巧

來源:互聯網
上載者:User

這篇文章主要通過程式碼分析javascript實現圖片上傳前台頁面,廢話不多說了,直接貼代碼了。

程式碼範例一:

<script>  //檢查圖片的格式是否正確,同時實現預覽  function setImagePreview(obj, localImagId, imgObjPreview) {   var array = new Array('gif', 'jpeg', 'png', 'jpg', 'bmp'); //可以上傳的檔案類型    if (obj.value == '') {    $.messager.alert("提示", "讓選擇要上傳的圖片!");    flag = false;    return false;   }   else {    var fileContentType = obj.value.match(/^(.*)(\.)(.{1,8})$/)[3]; //這個檔案類型正則很有用     ////布爾型變數     var isExists = false;    var objValue = obj.value;    try {     //對於IE判斷要上傳的檔案的大小      var fso = new ActiveXObject("Scripting.FileSystemObject");     fileLenth = parseInt(fso.getFile(objValue).size);    } catch (e) {     try {      //對於非IE獲得要上傳檔案的大小       fileLenth = parseInt(obj.files[0].size);     } catch (e) {      flag = false;      return false;     }    }    //迴圈判斷圖片的格式是否正確     for (var i in array) {     if (fileContentType.toLowerCase() == array[i].toLowerCase()) {      //圖片格式正確之後,根據瀏覽器的不同設定圖片的大小       if (obj.files && obj.files[0]) {       //Firefox下,直接設img屬性        imgObjPreview.style.display = 'block';       imgObjPreview.style.width = '180px';       imgObjPreview.style.height = '200px';       //Firefox7以上版本不能用上面的getAsDataURL()方式擷取,需要一下方式        imgObjPreview.src = window.URL.createObjectURL(obj.files[0]);       if (fileLenth > 102400) {        $.messager.alert("提示", "請選擇小於100k的圖片!");        flag = false;        return false;       }      }      else {       //IE下,使用濾鏡        obj.select();       var imgSrc = document.selection.createRange().text;       //必須設定初始大小        localImagId.style.width = "180px";       localImagId.style.height = "200px";       //圖片異常的捕捉,防止使用者修改尾碼來偽造圖片        try {        localImagId.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";        localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;       }       catch (e) {        $.messager.alert("提示", "您上傳的圖片格式不正確,請重新選擇!");        flag = false;        return false;       }       imgObjPreview.style.display = 'none';       document.selection.empty();      }      isExists = true;      flag = true;      return true;     }    }    if (isExists == false) {     $.messager.alert("提示", "上傳圖片類型不正確!");     flag = false;     return false;    }    flag = false;    return false;   }  }  </script>  <tr class="detailInfo">    <td align="right">     上傳照片:    </td>    <td align="left" >     <input type="file" id="idFile" name="idFile" width="150px" runat="server" onchange="javascript:setImagePreview(this,localImag,preview);" />    </td>    </tr>   <tr class="detailInfo">    <td align="right">     預 覽:    </td>    <td>     <div id="localImag">      <img id="preview" alt="預覽圖片" src="../img/userphoto.jpg" style="width: 150px; height: 170px;" />     </div>    </td>    </tr>

程式碼範例二:

<!doctype html> <html>  <head>   <meta charset="utf-8" />   <title>ImageDialog Examples</title>   <link rel="stylesheet" href="../themes/default/default.css" />   <script src="../kindeditor.js"></script>   <script src="../lang/zh_CN.js"></script>   <script>    KindEditor.ready(function(K) {     var editor = K.editor({      allowFileManager : true     });     K('#image1').click(function() {      editor.loadPlugin('image', function() {       editor.plugin.imageDialog({        imageUrl : K('#url1').val(),        clickFn : function(url, title, width, height, border, align) {         K('#url1').val(url);         editor.hideDialog();        }       });      });     });     K('#image2').click(function() {      editor.loadPlugin('image', function() {       editor.plugin.imageDialog({        showLocal : false,        imageUrl : K('#url2').val(),        clickFn : function(url, title, width, height, border, align) {         K('#url2').val(url);         editor.hideDialog();        }       });      });     });     K('#image3').click(function() {      editor.loadPlugin('image', function() {       editor.plugin.imageDialog({        showRemote : false,        imageUrl : K('#url3').val(),        clickFn : function(url, title, width, height, border, align) {         K('#url3').val(url);         editor.hideDialog();        }       });      });     });    });   </script>  </head>  <body>   <p><input type="text" id="url1" value="" /> <input type="button" id="image1" value="選擇圖片" />(網狀圖片 + 本地上傳)</p>   <p><input type="text" id="url2" value="" /> <input type="button" id="image2" value="選擇圖片" />(網狀圖片)</p>   <p><input type="text" id="url3" value="" /> <input type="button" id="image3" value="選擇圖片" />(本地上傳)</p>  </body> </html>

當點擊選擇圖片時載入該js。然後複製imageDialog,在image.js尋找它,會發現裡面跟這差不多的東西。這時就應該懂了,upload_json.jsp設定url,title,width,height,order,align,前台就可以使用了。

以上是本文對javascript實現圖片上傳前台頁面的全部內容,希望大家喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.