拖拽的過程就不說了,這里主要說一下如何在前端獲取到圖片的相關(guān)信息。
創(chuàng)新互聯(lián)致力于成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站,成都網(wǎng)站設(shè)計(jì),集團(tuán)網(wǎng)站建設(shè)等服務(wù)標(biāo)準(zhǔn)化,推過標(biāo)準(zhǔn)化降低中小企業(yè)的建站的成本,并持續(xù)提升建站的定制化服務(wù)水平進(jìn)行質(zhì)量交付,讓企業(yè)網(wǎng)站從市場(chǎng)競(jìng)爭中脫穎而出。 選擇創(chuàng)新互聯(lián),就選擇了安全、穩(wěn)定、美觀的網(wǎng)站建設(shè)服務(wù)!
html5里有一個(gè)fileReader的全局變量,用來讀取本地文件,比如txt,img等,下面是一個(gè)簡單的代碼。
function?checkFile(files){
var?file?=?files[0];
var?reader?=?new?FileReader();
//?show表示div?id='show'/div,用來展示圖片預(yù)覽的
if(!/image\/\w+/.test(file.type)){
show.innerHTML?=?"請(qǐng)確保文件為圖像類型";
return?false;
}
//?onload是異步操作
reader.onload?=?function(e){
show.innerHTML?=?'img?src="'+e.target.result+'"?alt="img"';
}
reader.readAsDataURL(file);
}
這樣就能夠在不上傳到服務(wù)器的前提下預(yù)覽圖片。當(dāng)然,這個(gè)問題的重點(diǎn)是獲取圖片的原始尺寸,html5里還提供了兩個(gè)變量來獲?。簄aturalWidth和naturalHeight,這兩個(gè)分別來獲取圖片的原始寬度和原始高度。
在上面的例子中,就能通過下面的方式獲取到:
var?width?=?e.target.naturalWidth;
var?height?=?e.target.naturalHeight;
還有一種情況就是,如果已經(jīng)存在頁面里的圖片,怎么獲取到原始尺寸呢,可以這樣:
var?img?=?document.getElementsByTagName('img')[0];?//?獲取到圖片
var?width?=?img.naturalWidth;
var?height?=?img.naturalHeight;
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" ""
html xmlns=""
head
meta http-equiv="Content-Type" content="text/html; charset=utf-8" /
titleTransform/title
style type="text/css"
.test-box{
width:600px;
margin:50px auto;}
.pic{
-webkit-transition:all 1s ease-in-out;
transition:all 1s ease-in-out;
cursor:pointer;}
.top-pic{
position:absolute;
transform:scale(0,0)}
.test-box:hover .top-pic{
-webkit-transform-origin:top right;
-webkit-transform:scale(1,1);}
.test-box:hover .bot-pic{
-webkit-transform:scale(0,0);
-webkit-transform-origin:bottom left;
opacity: .5;
-webkit-transform:rotate(120deg);
-webkit-transform-origin:bottom left;
}
/style
/head
body
div class="test-box"
img class="pic top-pic" src="test-pic01.jpg" /
img class="pic bot-pic" src="test-pic02.jpg" /
/div
/body
/html
隨便寫了幾個(gè)效果,沒有用到JS,不過要用到JS只要把觸發(fā)事件替換掉上面的hover就行了,比如:
$(".button").click(function () {
。。。
});
這里面用到CSS3,所以請(qǐng)不要用IE11以下的低版本瀏覽器,不然你啥都看不見
下載這個(gè)插件
然后
html:
divimg id="ImgPr" width="120" height="120" //div
divinput type="file" id="up" //div
jq:
$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120 });
預(yù)覽圖片
預(yù)覽功能的基本設(shè)計(jì)思路:創(chuàng)建一個(gè)img元素,再把文件域的value值賦值給img元素的src屬性。
form name="form4" id="form4" method="post" action="#"
input type="file" name="file4" id="file4" ōnchange="preview4()" /
img id="pic4" src="" alt="圖片在此顯示" width="120"/
/form
scrīpt type="text/javascrīpt"
function preview4(){
var x = document.getElementById("file4");
var y = document.getElementById("pic4");
if(!x || !x.value || !y)
return;
var patn = /\.jpg$|\.jpeg$|\.gif$/i;
if(patn.test(x.value)){
y.src = "" + x.value;
}
else{ alert("您選擇的似乎不是圖像文件。"); }
}
/scrīpt
試下效果:
如果你用的是Firefox(或Opera),可能會(huì)發(fā)現(xiàn)什么也沒有發(fā)生。是的,很不幸Firefox的安全策略不允許我們顯示一個(gè)用戶的本地圖像文件。不知道他們?yōu)槭裁匆@么做,我個(gè)人覺得圖像文件并不會(huì)造成嚴(yán)重的安全性問題。即使是不久前比較熱門的那個(gè)會(huì)引起Windows崩潰的jpeg文件,要顯示它的前提條件是用戶自己選擇了這個(gè)文件或者你知道這個(gè)文件在用戶硬盤上的準(zhǔn)確路徑。所以我想這種策略很可能來自于一個(gè)“懶惰”的開發(fā)人員,他并不想多寫一些程序來區(qū)分這個(gè)本地文件是一個(gè)圖像文件還是一個(gè)惡意文件,F(xiàn)irefox對(duì)安全性的要求讓他們有些過于敏感了。
讓Firefox顯示本地文件的唯一辦法就是修改它的默認(rèn)安全策略:
在Firefox的地址欄中輸入“about:config”
繼續(xù)輸入“security.checkloaduri”
雙擊下面列出來的一行文字,把它的值由true改為false
然后你可以再試試上面預(yù)覽,everything works well!可惜的是我們并不能要求所有的用戶都去修改這個(gè)值(更不用說修改的過程還挺麻煩),所以這對(duì)我們來說毫無意義。我們能做的也許就是接受Firefox不能預(yù)覽本地圖片這種“可笑”的局面。
用DOM來創(chuàng)建對(duì)象
在上面的XHTML代碼中,我們?yōu)榱祟A(yù)覽圖片,事先加入了一個(gè)沒有設(shè)置src的img對(duì)象。除去不美觀、代碼冗余之外,如果用戶瀏覽器不支持Javascrīpt,他不僅無法使用這個(gè)功能,還要接受頁面上一個(gè)永遠(yuǎn)不會(huì)顯示出來的破圖。要解決這個(gè)問題,我們就需要在“運(yùn)行時(shí)”再生成這個(gè)img對(duì)象,途徑還是DOM。
form name="form5" id="form5" method="post" action="#"
input type="file" name="file5" id="file5" ōnchange="preview5()"/
/form
scrīpt type="text/javascrīpt"
function preview5(){
var x = document.getElementById("file5");
if(!x || !x.value)
return;
var patn = /\.jpg$|\.jpeg$|\.gif$/i;
if(patn.test(x.value)){
var y = document.getElementById("img5");
if(y){ y.src = '' + x.value; }
else{
var img=document.createElement('img');
img.setAttribute('src',''+x.value);
img.setAttribute('width','120');
img.setAttribute('height','90');
img.setAttribute('id','img5');
document.getElementById('form5').appendChild(img);
}
}
else{ alert("您選擇的似乎不是圖像文件。"); }
}
/scrīpt
這個(gè)并不是那么簡單做出來的,一般情況下會(huì)加一段iframe代碼,模擬ajax上傳。
代碼很簡單,如下:
!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
""
html xmlns=""
head
meta http-equiv="Content-Type" content="text/html; charset=utf-8" /
titleBy:DragonDean/title
script type="text/javascript"
//下面用于圖片上傳預(yù)覽功能
function setImagePreview(avalue) {
var docObj=document.getElementById("doc");
var imgObjPreview=document.getElementById("preview");
if(docObj.files docObj.files[0])
{
//火狐下,直接設(shè)img屬性
imgObjPreview.style.display = 'block';
imgObjPreview.style.width = '150px';
imgObjPreview.style.height = '180px';
//imgObjPreview.src = docObj.files[0].getAsDataURL();
//火狐7以上版本不能用上面的getAsDataURL()方式獲取,需要一下方式
imgObjPreview.src = window.URL.createObjectURL(docObj.files[0]);
}
else
{
//IE下,使用濾鏡
docObj.select();
var imgSrc = document.selection.createRange().text;
var localImagId = document.getElementById("localImag");
//必須設(shè)置初始大小
localImagId.style.width = "150px";
localImagId.style.height = "180px";
//圖片異常的捕捉,防止用戶修改后綴來偽造圖片
try{
localImagId.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;
}
catch(e)
{
alert("您上傳的圖片格式不正確,請(qǐng)重新選擇!");
return false;
}
imgObjPreview.style.display = 'none';
document.selection.empty();
}
return true;
}
/script
/head
body
table width="100%" border="0" cellspacing="0" cellpadding="0"
tbody
tr
td height="101" align="center"
div id="localImag"img id="preview" src="" width="150" height="180" style="display: block; width: 150px; height: 180px;"/div
/td
/tr
tr
td align="center" style="padding-top:10px;"input type="file" name="file"
id="doc" style="width:150px;" onchange="javascript:setImagePreview();"/td
/tr
/tbody
/table
/body
/html