jquery實(shí)現(xiàn)圖片上傳前本地預(yù)覽
前段時(shí)間遇到一個(gè)問(wèn)題,前端想實(shí)現(xiàn)圖片上傳預(yù)覽(不經(jīng)過(guò)后端PHP或JAVA處理),用戶(hù)點(diǎn)擊file按鈕上傳文件,點(diǎn)擊確定馬上就能看到預(yù)覽的效果,但在實(shí)現(xiàn)的時(shí)候無(wú)論怎樣都取不到file上圖片的真實(shí)路徑,得到的反而是C:\fakepath\a.jpg,這個(gè)路徑是錯(cuò)誤的。百度之后得到說(shuō)瀏覽器基于保護(hù)用戶(hù)的相關(guān)安全措施,隱藏了上傳的真實(shí)路徑,用fakepath代替,當(dāng)然,調(diào)整瀏覽器的相關(guān)安全設(shè)置可以解決這個(gè)問(wèn)題。但我們不可能讓所有用戶(hù)都通過(guò)設(shè)置瀏覽器的安全設(shè)置來(lái)進(jìn)行圖片上傳,這種方法在網(wǎng)絡(luò)交互上顯然不現(xiàn)實(shí)。
名稱(chēng):圖片上傳本地預(yù)覽插件 v1.1
介紹:基于JQUERY擴(kuò)展,圖片上傳預(yù)覽插件 目前兼容瀏覽器(IE 谷歌 火狐) 不支持safari
插件網(wǎng)站: http://keleyi.com/keleyi/phtml/image/16.htm
參數(shù)說(shuō)明:
Img:圖片ID;
Width:預(yù)覽寬度;
Height:預(yù)覽高度;
ImgType:支持文件類(lèi)型;
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ò)誤,圖片類(lèi)型必須是" + 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" />
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JQuery實(shí)現(xiàn)自定義對(duì)話框的代碼
JavaScript為我們提供幾種對(duì)話框功能,但功能都十分有限;雖然在IE下可以通過(guò)模式窗體的方式創(chuàng)建更豐富的對(duì)話框功能,但畢竟只有IE得到支持。2008-06-06jquery插件validation實(shí)現(xiàn)驗(yàn)證身份證號(hào)等
這篇文章主要介紹了jquery插件validation實(shí)現(xiàn)驗(yàn)證身份證號(hào)、護(hù)照、電話號(hào)碼、email十分的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。2015-06-06jQuery實(shí)現(xiàn)購(gòu)物車(chē)多物品數(shù)量的加減+總價(jià)計(jì)算
這篇文章主要介紹了jQuery實(shí)現(xiàn)購(gòu)物車(chē)多物品數(shù)量的加減+總價(jià)計(jì)算,需要的朋友可以參考下2014-06-06jQuery插件slicebox實(shí)現(xiàn)3D動(dòng)畫(huà)圖片輪播切換特效
Slicebox是一款效果非常華麗的jquery和css3 3d幻燈片插件。Slicebox幻燈片插件能夠?qū)D片切片,然后做3d旋轉(zhuǎn)。Slicebox幻燈片插件共有4種效果,視覺(jué)沖擊感非常強(qiáng)。2015-04-04