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

jquery實現圖片上傳前本地預覽

 更新時間:2017年04月28日 11:41:07   作者:堆棧溢出  
這篇文章主要為大家詳細介紹了jquery實現圖片上傳前本地預覽功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

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

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

插件網站: http://keleyi.com/keleyi/phtml/image/16.htm

參數說明:

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

使用方法:

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

把需要進行預覽的IMG標簽外 套一個DIV 然后給上傳控件ID給予uploadPreview事件

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

實例:

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("選擇文件錯誤,圖片類型必須是" + 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()
   }
  })
 }
});

調用:

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

HTML結構:

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

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

相關文章

  • jquery蒙版控件實現代碼

    jquery蒙版控件實現代碼

    jquery蒙版控件實現代碼,學習jquery的朋友可以參考下。
    2010-12-12
  • jQuery中wrapInner()方法用法實例

    jQuery中wrapInner()方法用法實例

    這篇文章主要介紹了jQuery中wrapInner()方法用法,實例分析了wrapInner()方法的功能、定義及包裹匹配元素的使用技巧,需要的朋友可以參考下
    2015-01-01
  • jQuery中size()方法用法實例

    jQuery中size()方法用法實例

    這篇文章主要介紹了jQuery中size()方法用法,實例分析了size()方法返回對象集合中元素數目的使用技巧,具有一定的參考借鑒價值,需要的朋友可以參考下
    2014-12-12
  • jquery validation驗證表單插件

    jquery validation驗證表單插件

    這篇文章主要為大家詳細介紹了jquery validation驗證表單插件的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • jquery插件制作教程 txtHover

    jquery插件制作教程 txtHover

    該系列文章是我閱讀<jQuery Plugin Development Beginner's Guide>后的總結,有興趣的朋友可以去讀原版的書籍
    2012-08-08
  • JQuery實現自定義對話框的代碼

    JQuery實現自定義對話框的代碼

    JavaScript為我們提供幾種對話框功能,但功能都十分有限;雖然在IE下可以通過模式窗體的方式創(chuàng)建更豐富的對話框功能,但畢竟只有IE得到支持。
    2008-06-06
  • jquery插件validation實現驗證身份證號等

    jquery插件validation實現驗證身份證號等

    這篇文章主要介紹了jquery插件validation實現驗證身份證號、護照、電話號碼、email十分的簡單實用,有需要的小伙伴可以參考下。
    2015-06-06
  • jQuery實現購物車多物品數量的加減+總價計算

    jQuery實現購物車多物品數量的加減+總價計算

    這篇文章主要介紹了jQuery實現購物車多物品數量的加減+總價計算,需要的朋友可以參考下
    2014-06-06
  • jQuery插件slicebox實現3D動畫圖片輪播切換特效

    jQuery插件slicebox實現3D動畫圖片輪播切換特效

    Slicebox是一款效果非常華麗的jquery和css3 3d幻燈片插件。Slicebox幻燈片插件能夠將圖片切片,然后做3d旋轉。Slicebox幻燈片插件共有4種效果,視覺沖擊感非常強。
    2015-04-04
  • 淺析jquery unbind()方法移除元素綁定的事件

    淺析jquery unbind()方法移除元素綁定的事件

    下面小編就為大家?guī)硪黄獪\析jquery unbind()方法移除元素綁定的事件。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05

最新評論