溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jquery如何實(shí)現(xiàn)圖片上傳前本地預(yù)覽

發(fā)布時(shí)間:2021-06-24 14:56:41 來源:億速云 閱讀:388 作者:小新 欄目:web開發(fā)

這篇文章主要為大家展示了“jquery如何實(shí)現(xiàn)圖片上傳前本地預(yù)覽”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“jquery如何實(shí)現(xiàn)圖片上傳前本地預(yù)覽”這篇文章吧。

前段時(shí)間遇到一個(gè)問題,前端想實(shí)現(xiàn)圖片上傳預(yù)覽(不經(jīng)過后端PHP或JAVA處理),用戶點(diǎn)擊file按鈕上傳文件,點(diǎn)擊確定馬上就能看到預(yù)覽的效果,但在實(shí)現(xiàn)的時(shí)候無論怎樣都取不到file上圖片的真實(shí)路徑,得到的反而是C:\fakepath\a.jpg,這個(gè)路徑是錯(cuò)誤的。百度之后得到說瀏覽器基于保護(hù)用戶的相關(guān)安全措施,隱藏了上傳的真實(shí)路徑,用fakepath代替,當(dāng)然,調(diào)整瀏覽器的相關(guān)安全設(shè)置可以解決這個(gè)問題。但我們不可能讓所有用戶都通過設(shè)置瀏覽器的安全設(shè)置來進(jìn)行圖片上傳,這種方法在網(wǎng)絡(luò)交互上顯然不現(xiàn)實(shí)。

名稱:圖片上傳本地預(yù)覽插件 v1.1

介紹:基于JQUERY擴(kuò)展,圖片上傳預(yù)覽插件 目前兼容瀏覽器(IE 谷歌 火狐) 不支持safari

插件網(wǎng)站: http://keleyi.com/keleyi/phtml/image/16.htm

jquery如何實(shí)現(xiàn)圖片上傳前本地預(yù)覽

參數(shù)說明:

  Img:圖片ID;
  Width:預(yù)覽寬度;
  Height:預(yù)覽高度;
  ImgType:支持文件類型;
  Callback:選擇文件顯示圖片后回調(diào)方法;

使用方法:

<div>
<img id="ImgPr" width="120" height="120" /></div>
<input type="file" id="up" />

把需要進(jìn)行預(yù)覽的IMG標(biāo)簽外 套一個(gè)DIV 然后給上傳控件ID給予uploadPreview事件

$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120, ImgType: ["gif", "jpeg", "jpg", "bmp", "png"], Callback: function () { }});

實(shí)例:

jQuery.fn.extend({
 uploadPreview: function (opts) {
  var _self = this,
   _this = $(this);
  opts = jQuery.extend({
   Img: "ImgPr",
   Width: 100,
   Height: 100,
   ImgType: ["gif", "jpeg", "jpg", "bmp", "png"],
   Callback: function () {}
  }, opts || {});
  _self.getObjectURL = function (file) {
   var url = null;
   if (window.createObjectURL != undefined) {
    url = window.createObjectURL(file)
   } else if (window.URL != undefined) {
    url = window.URL.createObjectURL(file)
   } else if (window.webkitURL != undefined) {
    url = window.webkitURL.createObjectURL(file)
   }
   return url
  };
  _this.change(function () {
   if (this.value) {
    if (!RegExp("\.(" + opts.ImgType.join("|") + ")$", "i").test(this.value.toLowerCase())) {
     alert("選擇文件錯(cuò)誤,圖片類型必須是" + opts.ImgType.join(",") + "中的一種");
     this.value = "";
     return false
    }
//高版本Jquey使用 if ($.support.leadingWhitespace)
    if ($.browser.msie) { //低版本jquery中使用的方式
     try {
      $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))
     } catch (e) {
      var src = "";
      var obj = $("#" + opts.Img);
      var div = obj.parent("div")[0];
      _self.select();
      if (top != self) {
       window.parent.document.body.focus()
      } else {
       _self.blur()
      }
      src = document.selection.createRange().text;
      document.selection.empty();
      obj.hide();
      obj.parent("div").css({
       'filter': 'progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)',
       'width': opts.Width + 'px',
       'height': opts.Height + 'px'
      });
      div.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = src
     }
    } else {
     $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))
    }
    opts.Callback()
   }
  })
 }
});

調(diào)用:

$(function () {
 $("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120 });
});

HTML結(jié)構(gòu):

<div>
<img id="ImgPr" width="120" height="120" />
</div>
<input type="file" id="up" />

以上是“jquery如何實(shí)現(xiàn)圖片上傳前本地預(yù)覽”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI