亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

html5 拖拽上傳圖片實例演示

2024-08-26 00:14:53
字體:
來源:轉載
供稿:網友
因為標題寫的是實例,所以本次就不做講解了,因為這個實例我也算是東拼西湊整出來的,參考了大概5、6款拖拽上傳的插件和demo,然后把其中好的地方挑出來,最后就成了這么一個實例,一起來看下吧(地址不能保證長久有效,如果失效請在文章最后點擊demo下載):
 
界面樣式我是參考了一個國外的相冊網站,改動不大,只是把鳥語轉換成中文,以及上傳時的樣式也進行了改動,之所以選這個的原因就是,我很容易做擴展,它支持3種方式添加圖片,一種拖拽上傳,一種常規的選擇文件上傳,另外的就是添加網絡圖片。它很巧妙的把三種上傳模式整合到了一起,而且你可以用IE瀏覽器瀏覽下,如果不支持HTML5,是沒有拖拽上傳圖片的提示的,如圖:
 
拖拽上傳最重要的就是js部分的代碼,它實現了70%的功能,另外30%僅僅是把圖片信息提交到后臺,然后做對應的處理,比如壓縮啊,裁剪啊云云。所以先來看下js實現代碼吧。

復制代碼 代碼如下:www.CuoXIn.com

$().ready(function(){
if($.browser.safari || $.browser.mozilla){
$('#dtb-msg1 .compatible').show();
$('#dtb-msg1 .notcompatible').hide();
$('#drop_zone_home').hover(function(){
$(this).children('p').stop().animate({top:'0px'},200);
},function(){
$(this).children('p').stop().animate({top:'-44px'},200);
});
//功能實現
$(document).on({
dragleave:function(e){
e.preventDefault();
$('.dashboard_target_box').removeClass('over');
},
drop:function(e){
e.preventDefault();
//$('.dashboard_target_box').removeClass('over');
},
dragenter:function(e){
e.preventDefault();
$('.dashboard_target_box').addClass('over');
},
dragover:function(e){
e.preventDefault();
$('.dashboard_target_box').addClass('over');
}
});
var box = document.getElementById('target_box');
box.addEventListener("drop",function(e){
e.preventDefault();
//獲取文件列表
var fileList = e.dataTransfer.files;
var img = document.createElement('img');
//檢測是否是拖拽文件到頁面的操作
if(fileList.length == 0){
$('.dashboard_target_box').removeClass('over');
return;
}
//檢測文件是不是圖片
if(fileList[0].type.indexOf('image') === -1){
$('.dashboard_target_box').removeClass('over');
return;
}
if($.browser.safari){
//Chrome8+
img.src = window.webkitURL.createObjectURL(fileList[0]);
}else if($.browser.mozilla){
//FF4+
img.src = window.URL.createObjectURL(fileList[0]);
}else{
//實例化file reader對象
var reader = new FileReader();
reader.onload = function(e){
img.src = this.result;
$(document.body).appendChild(img);
}
reader.readAsDataURL(fileList[0]);
}
var xhr = new XMLHttpRequest();
xhr.open("post", "test.php", true);
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
xhr.upload.addEventListener("progress", function(e){
$("#dtb-msg3").hide();
$("#dtb-msg4 span").show();
$("#dtb-msg4").children('span').eq(1).css({width:'0px'});
$('.show').html('');
if(e.lengthComputable){
var loaded = Math.ceil((e.loaded / e.total) * 100);
$("#dtb-msg4").children('span').eq(1).css({width:(loaded*2)+'px'});
}
}, false);
xhr.addEventListener("load", function(e){
$('.dashboard_target_box').removeClass('over');
$("#dtb-msg3").show();
$("#dtb-msg4 span").hide();
var result = jQuery.parseJSON(e.target.responseText);
alert(result.filename);
$('.show').append(result.img);
}, false);
var fd = new FormData();
fd.append('xfile', fileList[0]);
xhr.send(fd);
},false);
}else{
$('#dtb-msg1 .compatible').hide();
$('#dtb-msg1 .notcompatible').show();
}
});

開始我是先判斷瀏覽器類型,因為剛才介紹過,不同瀏覽器看到的是不同界面。主要實現代碼是從“功能實現”開始的,這塊具體為何這樣操作,原理是什么,我就不多說了,大家可以參考下這篇文章:《人人網首頁拖拽上傳詳解(HTML5 Drag&Drop、FileReader API、formdata)》,不過ajax上傳部分的代碼還是有點不一樣的,因為人人那個似乎有點麻煩,我就另尋途徑了。
  最后就是上傳部分的PHP代碼了,這里我只是提供個參考,你可以根據項目的需求來自己編寫。

復制代碼 代碼如下:www.CuoXIn.com

$r = new stdClass();
header('content-type: application/json');
$maxsize = 10; //Mb
if($_FILES['xfile']['size'] > ($maxsize * 1048576)){
$r->error = "圖片大小不超過 $maxsize MB";
}
$folder = 'files/';
if(!is_dir($folder)){
mkdir($folder);
}
$folder .= $_POST['folder'] ? $_POST['folder'] . '/' : '';
if(!is_dir($folder)){
mkdir($folder);
}
if(preg_match('/image/i', $_FILES['xfile']['type'])){
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . '.jpg';
}else{
$tld = split(',', $_FILES['xfile']['name']);
$tld = $tld[count($tld) - 1];
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . $tld;
}
$types = Array('image/png', 'image/gif', 'image/jpeg');
if(in_array($_FILES['xfile']['type'], $types)){
$source = file_get_contents($_FILES["xfile"]["tmp_name"]);
imageresize($source, $filename, $_POST['width'], $_POST['height'], $_POST['crop'], $_POST['quality']);
}else{
move_uploaded_file($_FILES["xfile"]["tmp_name"], $filename);
}
$path = str_replace('test.php', '', $_SERVER['SCRIPT_NAME']);
$r->filename = $filename;
$r->path = $path;
$r->img = '<img src="' . $path . $filename . '" alt="image" />';
echo json_encode($r);
function imageresize($source, $destination, $width = 0, $height = 0, $crop = false, $quality = 80) {
$quality = $quality ? $quality : 80;
$image = imagecreatefromstring($source);
if ($image) {
// Get dimensions
$w = imagesx($image);
$h = imagesy($image);
if (($width && $w > $width) || ($height && $h > $height)) {
$ratio = $w / $h;
if (($ratio >= 1 || $height == 0) && $width && !$crop) {
$new_height = $width / $ratio;
$new_width = $width;
} elseif ($crop && $ratio <= ($width / $height)) {
$new_height = $width / $ratio;
$new_width = $width;
} else {
$new_width = $height * $ratio;
$new_height = $height;
}
} else {
$new_width = $w;
$new_height = $h;
}
$x_mid = $new_width * .5; //horizontal middle
$y_mid = $new_height * .5; //vertical middle
// Resample
error_log('height: ' . $new_height . ' - width: ' . $new_width);
$new = imagecreatetruecolor(round($new_width), round($new_height));
imagecopyresampled($new, $image, 0, 0, 0, 0, $new_width, $new_height, $w, $h);
// Crop
if ($crop) {
$crop = imagecreatetruecolor($width ? $width : $new_width, $height ? $height : $new_height);
imagecopyresampled($crop, $new, 0, 0, ($x_mid - ($width * .5)), 0, $width, $height, $width, $height);
//($y_mid - ($height * .5))
}
// Output
// Enable interlancing [for progressive JPEG]
imageinterlace($crop ? $crop : $new, true);
$dext = strtolower(pathinfo($destination, PATHINFO_EXTENSION));
if ($dext == '') {
$dext = $ext;
$destination .= '.' . $ext;
}
switch ($dext) {
case 'jpeg':
case 'jpg':
imagejpeg($crop ? $crop : $new, $destination, $quality);
break;
case 'png':
$pngQuality = ($quality - 100) / 11.111111;
$pngQuality = round(abs($pngQuality));
imagepng($crop ? $crop : $new, $destination, $pngQuality);
break;
case 'gif':
imagegif($crop ? $crop : $new, $destination);
break;
}
@imagedestroy($image);
@imagedestroy($new);
@imagedestroy($crop);
}
}

PHP最終會返回一個JSON格式的數組,我返回的信息就是圖片地址、名稱,還有段img的html代碼,最后在js那邊獲取到json數組并處理,至此,操作結束。
文章最開始提到,還有點擊選擇文件上傳和網絡圖片,因為這2個不屬于這次的主題范圍內,就不說了。況且這2個功能實現起來都不麻煩。
demo下載

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
操91在线视频| 欧美另类极品videosbest最新版本| 国产精品白丝av嫩草影院| 九九热精品在线| 日本高清久久天堂| 日韩在线观看网站| 国模gogo一区二区大胆私拍| 亚洲天堂开心观看| 精品人伦一区二区三区蜜桃网站| 日韩精品有码在线观看| 亚洲国产欧美一区二区三区久久| 日韩激情视频在线| 国产a级全部精品| 亚洲精品免费一区二区三区| 欧美寡妇偷汉性猛交| 国产一区二区三区直播精品电影| 日韩欧中文字幕| 亚洲欧美中文日韩在线| 日韩欧美在线视频日韩欧美在线视频| 亚洲黄一区二区| 日韩欧美中文在线| 欧美日韩国产综合新一区| 日韩精品高清在线| 日韩福利伦理影院免费| 日韩欧美在线国产| 亚洲成av人乱码色午夜| 欧美国产日本在线| 久久精品人人爽| 久久久亚洲国产天美传媒修理工| 成人国产精品久久久久久亚洲| 中文字幕成人精品久久不卡| 欧美性少妇18aaaa视频| 亚洲欧美成人网| 精品小视频在线| 国外成人性视频| 日韩中文在线中文网三级| 91av在线免费观看视频| 色妞一区二区三区| 国产视频欧美视频| 欧美激情中文字幕在线| 久久69精品久久久久久久电影好| 亚洲精品自拍第一页| 日韩精品在线视频| 琪琪亚洲精品午夜在线| 久久精彩免费视频| 久久91亚洲精品中文字幕奶水| 狠狠躁18三区二区一区| 一本久久综合亚洲鲁鲁| 国产精品久久久久久五月尺| 日韩中文字幕在线播放| 8050国产精品久久久久久| 国产精品美女久久久免费| 福利二区91精品bt7086| 欧美黑人视频一区| 韩剧1988在线观看免费完整版| 日韩av在线精品| 成人在线视频福利| 欧美一区第一页| 亚洲性生活视频在线观看| 自拍偷拍亚洲在线| 欧美精品在线观看| 91人成网站www| 欧美亚洲激情视频| 国产精品久久久久秋霞鲁丝| 精品国内自产拍在线观看| 欧美亚洲国产视频小说| 国产亚洲aⅴaaaaaa毛片| 久久久久久久电影一区| 国产精品中文久久久久久久| 亚洲的天堂在线中文字幕| 色婷婷av一区二区三区在线观看| 亚洲免费精彩视频| 国产精品久久久久免费a∨| 国产亚洲成av人片在线观看桃| 91精品国产高清久久久久久| 永久免费精品影视网站| 国产成人精品一区| 亚洲成人a**站| 91亚洲国产成人精品性色| 日韩高清电影免费观看完整版| 日韩精品中文字幕久久臀| 久久精品视频中文字幕| 亚洲人av在线影院| 92福利视频午夜1000合集在线观看| 久久成人综合视频| 欧美激情精品久久久久久久变态| 国产午夜精品美女视频明星a级| 中文国产亚洲喷潮| 欧美极品美女电影一区| 91精品久久久久久久久久另类| 日本国产一区二区三区| 欧美激情精品久久久久久黑人| 精品国产一区二区三区久久狼黑人| 欧美日韩免费观看中文| 亚洲福利视频网| 91国产精品91| 色伦专区97中文字幕| 成人啪啪免费看| 国产成人精品一区二区三区| 国产精品久久一区| 欧美成人全部免费| 国产精品久久久久久久久久久新郎| 亚洲深夜福利网站| 91精品国产成人www| 久久久综合av| 亚洲偷欧美偷国内偷| 国产亚洲在线播放| 国产日韩欧美电影在线观看| 亚洲2020天天堂在线观看| 成人国产精品免费视频| 中文字幕精品在线| 国产成人一区二区| 一本色道久久综合狠狠躁篇怎么玩| 欧美激情精品久久久| 色综合91久久精品中文字幕| 青青久久av北条麻妃海外网| 日韩三级影视基地| 久久躁日日躁aaaaxxxx| 欧美野外猛男的大粗鳮| 欧美多人乱p欧美4p久久| 日韩欧美一区视频| 热久久美女精品天天吊色| 日韩a**站在线观看| 日韩成人av在线播放| 欧美激情国内偷拍| 美女999久久久精品视频| 欧美做爰性生交视频| 午夜精品久久久99热福利| 欧美二区在线播放| 97视频免费看| 国产精品视频免费在线| 91在线观看免费观看| 成人a级免费视频| 久久久久久久国产精品| 美女久久久久久久| 一区二区在线免费视频| 国产热re99久久6国产精品| 亚洲国内精品视频| 91av在线免费观看视频| 97在线日本国产| 在线播放日韩欧美| 久久久99免费视频| 人九九综合九九宗合| 亚洲女人天堂成人av在线| 国产成人av在线| 亚洲最大的成人网| 亚洲黄色www| 亚洲日韩欧美视频一区| 国产欧美婷婷中文| 欧美视频第一页| 亚洲精品影视在线观看| 欧美黄色免费网站| 午夜精品久久久久久久白皮肤| 亚洲欧美三级伦理| 亚洲第一区第一页| 91国内产香蕉| 夜夜狂射影院欧美极品| 美女视频黄免费的亚洲男人天堂| 欧美乱大交做爰xxxⅹ性3| 国产欧美精品一区二区三区介绍| 国产69精品99久久久久久宅男| 日韩中文字幕免费视频| 亚洲一区中文字幕| 亚洲xxx视频|