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

javascript圖片預覽和上傳(兼容IE)

 更新時間:2017年03月15日 14:30:52   作者:Fayin  
這篇文章主要為大家詳細介紹了javascript圖片預覽和上傳的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了js圖片預覽和上傳的具體代碼,供大家參考,具體內容如下

var dailiApply = {

   change: function (evt) {
    evt.preventDefault();
    var pic = document.getElementById("preview"),
     file = document.getElementById("f");

    var ext=file.value.substring(file.value.lastIndexOf(".")+1).toLowerCase();
    // gif在IE瀏覽器暫時無法顯示
    if(ext!='png'&&ext!='jpg'&&ext!='jpeg'){
     alert("圖片的格式必須為png或者jpg或者jpeg格式!");
     return;
    }
    var isIE = navigator.userAgent.match(/MSIE/)!= null,
     isIE6 = navigator.userAgent.match(/MSIE 6.0/)!= null;

    if(isIE) {
     file.select();
     var reallocalpath = document.selection.createRange().text;

     // IE6瀏覽器設置img的src為本地路徑可以直接顯示圖片
     if (isIE6) {
      pic.src = reallocalpath;
     }else {
      // 非IE6版本的IE由于安全問題直接設置img的src無法顯示本地圖片,但是可以通過濾鏡來實現(xiàn)
      pic.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='image',src=\"" + reallocalpath + "\")";
      // 設置img的src為base64編碼的透明圖片 取消顯示瀏覽器默認圖片
      pic.src = 'data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==';
     }
    }else {
     var file_arr = file.files;
     var ul = $(".weui_uploader_files");
     if(file_arr.length < 7) {
      for(var key in file_arr) {
       if(file_arr.hasOwnProperty(key)) {
        var f = file_arr[key];
        var url = URL.createObjectURL(f);
        var reader = new FileReader();
        console.log(f);
        reader.readAsDataURL(f);
        n +=1;
        if(n < 7) {
         reader._onload = function(e) {

          // 拼接顯示預覽圖片的html
          var list = $("<li class='weui_uploader_file' style='position: relative'>" +
           "<img id='preview" + n + "' class=preview_li' style='width: 100%;height: 100%'>" +
           "<span id='delImg" + n+ "' style='position: absolute; top: 0; right: 4px; color: #e4007f'>X</span></li>");
          ul.append(list);
          // 將轉化后的圖片地址放在img中
          var pic = document.getElementById('preview' + n);
          //pic.src = this.result;
          pic.src=url;
          dailiApply.compress(f, .7,undefined);
          //images.push(f);
          document.getElementById('delImg' + n).addEventListener("click", function () {
           $(this).parent().remove();
           --n;
          });

         };
         reader._onload();
        }else {
         $.alert("最多上傳6張圖片");
         n = 6;
        }
       }
      }
     }else {
      $.alert("最多上傳6張圖片");
     }
    }
    return false;
   },
   /**
    * @param {Object} f input選擇的圖片 必填
    * @param {String} quality  圖片壓縮的質量[0, 1]
    * @param {String} output_img_type  輸出圖片的類型
    */
   compress: function (f, quality, output_img_type) {
    var mime_type = "image/jpeg";
    if(output_img_type!=undefined && output_img_type=="image/png"){
     mime_type = "image/png";
    }
    createImageBitmap(f).then(function(imageBitmap) {
     var max = 1000; // 設置最大分辨率
     var c_w = '';
     var c_h = '';
     var width = imageBitmap.width;
     var height = imageBitmap.height;
     // 等比例縮放
     if (width > max || height > max) {
      if (width > height) {
       c_w = max;
       c_h = max * height / width;
      } else {
       c_h = max;
       c_w = max * width / height;
      }
     }else {  // 不縮放
      c_w = width;
      c_h = height;
     }

     var canvas = document.createElement('canvas');
     canvas.width = c_w;
     canvas.height = c_h;
     var ctx = canvas.getContext('2d');
     ctx.drawImage(imageBitmap,0,0, width, height, 0, 0, c_w, c_h);
     canvas.toBlob(function(blob){
      images.push(blob);
     },mime_type, quality);
    });
   },
   submit: function () {
    var content = $(".weui_textarea").val().trim();
    var xhr = new XMLHttpRequest();
    var fd = new FormData(document.getElementById('uploadForm'));
    $.each(images,function(i,e){
     fd.append("images", e);
    });
    fd.append("remark", content);
    fd.append("substationproxyId", 8);
    console.log(images);
    console.log(fd);
    if(content) {
     $.ajax({
      url: CONFIG.API.addSubProxyRecruit,
      type: "POST",
      data: fd,

      processData: false, // tell jQuery not to process the data
      contentType: false, // tell jQuery not to set contentType
      beforeSend: function (xhr) {
       $.showLoading();
       $(this).prop("disabled", true)
      },
      success: function (json) {
       console.log(json);
       $.hideLoading();
       $(this).prop("disabled", false);
       if(json.errorCode == 0) {
        $.alert("保存成功", function () {
         location.reload();
        })
       }else if(json.errorCode == "-101") {
        $.alert('出錯:' +json.message, function () {
         location.href = CONFIG.HTML.login;
        });
       }else {
        $.alert(json.message, function () {

        })
       }
      }
     });
    }else {
     $.alert('請輸入內容');
    }

   }

  };

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • JavaScript中Function詳解

    JavaScript中Function詳解

    函數(shù)是由關鍵字function、函數(shù)名加一組參數(shù)及置于大括號中需要執(zhí)行的一段語義定義的。今天我們就來詳細講解一下JavaScript中的Function。
    2015-02-02
  • 跟我學習javascript的最新標準ES6

    跟我學習javascript的最新標準ES6

    跟我學習javascript的最新標準ECMAScript 6,ES6(ECMAScript 6)是即將到來的新版本JavaScript語言的標準,代號harmony,感興趣的小伙伴們可以參考一下
    2015-11-11
  • JavaScript必知必會(五) eval 的使用

    JavaScript必知必會(五) eval 的使用

    這篇文章主要介紹了JavaScript必知必會(五) eval 的使用 的相關資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • js獲取指定日期前后的日期代碼

    js獲取指定日期前后的日期代碼

    js獲取指定日期前后的日期,在實際應用中還是比較實用的,下面為大家簡單介紹下具體的實現(xiàn)過程,有需要的朋友可以參考下
    2013-08-08
  • JavaScript 檢測文件的類型的方法

    JavaScript 檢測文件的類型的方法

    在日常工作中,文件上傳是一個很常見的功能。在某些情況下,我們希望能限制文件上傳的類型,比如限制只能上傳 PNG 格式的圖片。本文就將針對這個問題,來講解如何檢測文件的類型
    2021-05-05
  • ppk談JavaScript style屬性

    ppk談JavaScript style屬性

    JavaScript允許你改變站點的CSS表示層。如果想把用戶的眼球吸引到那些你希望他們關注的頁面元素上,改變樣式是極佳的(也是很普遍的)方式。
    2008-10-10
  • Ajax高級筆記 JavaScript高級程序設計筆記

    Ajax高級筆記 JavaScript高級程序設計筆記

    這篇文章主要介紹了Ajax高級筆記 JavaScript高級程序設計筆記,需要的朋友可以參考下
    2017-06-06
  • JS 學習筆記 防止發(fā)生命名沖突

    JS 學習筆記 防止發(fā)生命名沖突

    為了防止發(fā)生命名沖突,可以建立自己的代碼庫。
    2009-07-07
  • bootstrap timepicker在angular中取值并轉化為時間戳

    bootstrap timepicker在angular中取值并轉化為時間戳

    這篇文章主要介紹了bootstrap timepicker在angular中取值并轉化為時間戳的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 微信小程序實現(xiàn)圖片上傳放大預覽刪除代碼

    微信小程序實現(xiàn)圖片上傳放大預覽刪除代碼

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)圖片上傳放大預覽刪除代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07

最新評論