html5中文学习网

您的位置: 首页 > html5教程 > 入门教程 » 正文

html5 拖拽上传图片实例演示_html5教程技巧

[ ] 已经帮助:人解决问题
点评:拖拽上传最重要的就是js部分的代码,它实现了70%的功能,另外30%仅仅是把图片信息提交到后台,然后做对应的处理,比如压缩啊,裁剪啊云云,感兴趣的朋友可以参考下哈,希望可以帮助到你
因为标题写的是实例,所以本次就不做讲解了,因为这个实例我也算是东拼西凑整出来的,参考了大概5、6款拖拽上传的插件和demo,然后把其中好的地方挑出来,最后就成了这么一个实例,一起来看下吧(地址不能保证长久有效,如果失效请在文章最后点击demo下载): 7jBHTML5中文学习网 - HTML5先行者学习网
 7jBHTML5中文学习网 - HTML5先行者学习网
界面样式我是参考了一个国外的相册网站,改动不大,只是把鸟语转换成中文,以及上传时的样式也进行了改动,之所以选这个的原因就是,我很容易做扩展,它支持3种方式添加图片,一种拖拽上传,一种常规的选择文件上传,另外的就是添加网络图片。它很巧妙的把三种上传模式整合到了一起,而且你可以用IE浏览器浏览下,如果不支持HTML5,是没有拖拽上传图片的提示的,如图: 7jBHTML5中文学习网 - HTML5先行者学习网
 7jBHTML5中文学习网 - HTML5先行者学习网
拖拽上传最重要的就是js部分的代码,它实现了70%的功能,另外30%仅仅是把图片信息提交到后台,然后做对应的处理,比如压缩啊,裁剪啊云云。所以先来看下js实现代码吧。 7jBHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
7jBHTML5中文学习网 - HTML5先行者学习网
$().ready(function(){ 7jBHTML5中文学习网 - HTML5先行者学习网
if($.browser.safari || $.browser.mozilla){ 7jBHTML5中文学习网 - HTML5先行者学习网
$('#dtb-msg1 .compatible').show(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('#dtb-msg1 .notcompatible').hide(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('#drop_zone_home').hover(function(){ 7jBHTML5中文学习网 - HTML5先行者学习网
$(this).children('p').stop().animate({top:'0px'},200); 7jBHTML5中文学习网 - HTML5先行者学习网
},function(){ 7jBHTML5中文学习网 - HTML5先行者学习网
$(this).children('p').stop().animate({top:'-44px'},200); 7jBHTML5中文学习网 - HTML5先行者学习网
}); 7jBHTML5中文学习网 - HTML5先行者学习网
//功能实现 7jBHTML5中文学习网 - HTML5先行者学习网
$(document).on({ 7jBHTML5中文学习网 - HTML5先行者学习网
dragleave:function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
e.preventDefault(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').removeClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
}, 7jBHTML5中文学习网 - HTML5先行者学习网
drop:function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
e.preventDefault(); 7jBHTML5中文学习网 - HTML5先行者学习网
//$('.dashboard_target_box').removeClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
}, 7jBHTML5中文学习网 - HTML5先行者学习网
dragenter:function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
e.preventDefault(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').addClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
}, 7jBHTML5中文学习网 - HTML5先行者学习网
dragover:function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
e.preventDefault(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').addClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
}); 7jBHTML5中文学习网 - HTML5先行者学习网
var box = document.getElementById('target_box'); 7jBHTML5中文学习网 - HTML5先行者学习网
box.addEventListener("drop",function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
e.preventDefault(); 7jBHTML5中文学习网 - HTML5先行者学习网
//获取文件列表 7jBHTML5中文学习网 - HTML5先行者学习网
var fileList = e.dataTransfer.files; 7jBHTML5中文学习网 - HTML5先行者学习网
var img = document.createElement('img'); 7jBHTML5中文学习网 - HTML5先行者学习网
//检测是否是拖拽文件到页面的操作 7jBHTML5中文学习网 - HTML5先行者学习网
if(fileList.length == 0){ 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').removeClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
return; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
//检测文件是不是图片 7jBHTML5中文学习网 - HTML5先行者学习网
if(fileList[0].type.indexOf('image') === -1){ 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').removeClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
return; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
if($.browser.safari){ 7jBHTML5中文学习网 - HTML5先行者学习网
//Chrome8+ 7jBHTML5中文学习网 - HTML5先行者学习网
img.src = window.webkitURL.createObjectURL(fileList[0]); 7jBHTML5中文学习网 - HTML5先行者学习网
}else if($.browser.mozilla){ 7jBHTML5中文学习网 - HTML5先行者学习网
//FF4+ 7jBHTML5中文学习网 - HTML5先行者学习网
img.src = window.URL.createObjectURL(fileList[0]); 7jBHTML5中文学习网 - HTML5先行者学习网
}else{ 7jBHTML5中文学习网 - HTML5先行者学习网
//实例化file reader对象 7jBHTML5中文学习网 - HTML5先行者学习网
var reader = new FileReader(); 7jBHTML5中文学习网 - HTML5先行者学习网
reader.onload = function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
img.src = this.result; 7jBHTML5中文学习网 - HTML5先行者学习网
$(document.body).appendChild(img); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
reader.readAsDataURL(fileList[0]); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
var xhr = new XMLHttpRequest(); 7jBHTML5中文学习网 - HTML5先行者学习网
xhr.open("post", "test.php", true); 7jBHTML5中文学习网 - HTML5先行者学习网
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest"); 7jBHTML5中文学习网 - HTML5先行者学习网
xhr.upload.addEventListener("progress", function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg3").hide(); 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg4 span").show(); 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg4").children('span').eq(1).css({width:'0px'}); 7jBHTML5中文学习网 - HTML5先行者学习网
$('.show').html(''); 7jBHTML5中文学习网 - HTML5先行者学习网
if(e.lengthComputable){ 7jBHTML5中文学习网 - HTML5先行者学习网
var loaded = Math.ceil((e.loaded / e.total) * 100); 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg4").children('span').eq(1).css({width:(loaded*2)+'px'}); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
}, false); 7jBHTML5中文学习网 - HTML5先行者学习网
xhr.addEventListener("load", function(e){ 7jBHTML5中文学习网 - HTML5先行者学习网
$('.dashboard_target_box').removeClass('over'); 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg3").show(); 7jBHTML5中文学习网 - HTML5先行者学习网
$("#dtb-msg4 span").hide(); 7jBHTML5中文学习网 - HTML5先行者学习网
var result = jQuery.parseJSON(e.target.responseText); 7jBHTML5中文学习网 - HTML5先行者学习网
alert(result.filename); 7jBHTML5中文学习网 - HTML5先行者学习网
$('.show').append(result.img); 7jBHTML5中文学习网 - HTML5先行者学习网
}, false); 7jBHTML5中文学习网 - HTML5先行者学习网
var fd = new FormData(); 7jBHTML5中文学习网 - HTML5先行者学习网
fd.append('xfile', fileList[0]); 7jBHTML5中文学习网 - HTML5先行者学习网
xhr.send(fd); 7jBHTML5中文学习网 - HTML5先行者学习网
},false); 7jBHTML5中文学习网 - HTML5先行者学习网
}else{ 7jBHTML5中文学习网 - HTML5先行者学习网
$('#dtb-msg1 .compatible').hide(); 7jBHTML5中文学习网 - HTML5先行者学习网
$('#dtb-msg1 .notcompatible').show(); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
}); 7jBHTML5中文学习网 - HTML5先行者学习网
7jBHTML5中文学习网 - HTML5先行者学习网
开始我是先判断浏览器类型,因为刚才介绍过,不同浏览器看到的是不同界面。主要实现代码是从“功能实现”开始的,这块具体为何这样操作,原理是什么,我就不多说了,大家可以参考下这篇文章:《人人网首页拖拽上传详解(HTML5 Drag&Drop、FileReader API、formdata)》,不过ajax上传部分的代码还是有点不一样的,因为人人那个似乎有点麻烦,我就另寻途径了。 7jBHTML5中文学习网 - HTML5先行者学习网
  最后就是上传部分的PHP代码了,这里我只是提供个参考,你可以根据项目的需求来自己编写。 7jBHTML5中文学习网 - HTML5先行者学习网

复制代码
代码如下:
7jBHTML5中文学习网 - HTML5先行者学习网
$r = new stdClass(); 7jBHTML5中文学习网 - HTML5先行者学习网
header('content-type: application/json'); 7jBHTML5中文学习网 - HTML5先行者学习网
$maxsize = 10; //Mb 7jBHTML5中文学习网 - HTML5先行者学习网
if($_FILES['xfile']['size'] > ($maxsize * 1048576)){ 7jBHTML5中文学习网 - HTML5先行者学习网
$r->error = "图片大小不超过 $maxsize MB"; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
$folder = 'files/'; 7jBHTML5中文学习网 - HTML5先行者学习网
if(!is_dir($folder)){ 7jBHTML5中文学习网 - HTML5先行者学习网
mkdir($folder); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
$folder .= $_POST['folder'] ? $_POST['folder'] . '/' : ''; 7jBHTML5中文学习网 - HTML5先行者学习网
if(!is_dir($folder)){ 7jBHTML5中文学习网 - HTML5先行者学习网
mkdir($folder); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
if(preg_match('/image/i', $_FILES['xfile']['type'])){ 7jBHTML5中文学习网 - HTML5先行者学习网
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . '.jpg'; 7jBHTML5中文学习网 - HTML5先行者学习网
}else{ 7jBHTML5中文学习网 - HTML5先行者学习网
$tld = split(',', $_FILES['xfile']['name']); 7jBHTML5中文学习网 - HTML5先行者学习网
$tld = $tld[count($tld) - 1]; 7jBHTML5中文学习网 - HTML5先行者学习网
$filename = $_POST['value'] ? $_POST['value'] : $folder . sha1(@microtime() . '-' . $_FILES['xfile']['name']) . $tld; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
$types = Array('image/png', 'image/gif', 'image/jpeg'); 7jBHTML5中文学习网 - HTML5先行者学习网
if(in_array($_FILES['xfile']['type'], $types)){ 7jBHTML5中文学习网 - HTML5先行者学习网
$source = file_get_contents($_FILES["xfile"]["tmp_name"]); 7jBHTML5中文学习网 - HTML5先行者学习网
imageresize($source, $filename, $_POST['width'], $_POST['height'], $_POST['crop'], $_POST['quality']); 7jBHTML5中文学习网 - HTML5先行者学习网
}else{ 7jBHTML5中文学习网 - HTML5先行者学习网
move_uploaded_file($_FILES["xfile"]["tmp_name"], $filename); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
$path = str_replace('test.php', '', $_SERVER['SCRIPT_NAME']); 7jBHTML5中文学习网 - HTML5先行者学习网
$r->filename = $filename; 7jBHTML5中文学习网 - HTML5先行者学习网
$r->path = $path; 7jBHTML5中文学习网 - HTML5先行者学习网
$r->img = '<img src="' . $path . $filename . '" alt="image" />'; 7jBHTML5中文学习网 - HTML5先行者学习网
echo json_encode($r); 7jBHTML5中文学习网 - HTML5先行者学习网
function imageresize($source, $destination, $width = 0, $height = 0, $crop = false, $quality = 80) { 7jBHTML5中文学习网 - HTML5先行者学习网
$quality = $quality ? $quality : 80; 7jBHTML5中文学习网 - HTML5先行者学习网
$image = imagecreatefromstring($source); 7jBHTML5中文学习网 - HTML5先行者学习网
if ($image) { 7jBHTML5中文学习网 - HTML5先行者学习网
// Get dimensions 7jBHTML5中文学习网 - HTML5先行者学习网
$w = imagesx($image); 7jBHTML5中文学习网 - HTML5先行者学习网
$h = imagesy($image); 7jBHTML5中文学习网 - HTML5先行者学习网
if (($width && $w > $width) || ($height && $h > $height)) { 7jBHTML5中文学习网 - HTML5先行者学习网
$ratio = $w / $h; 7jBHTML5中文学习网 - HTML5先行者学习网
if (($ratio >= 1 || $height == 0) && $width && !$crop) { 7jBHTML5中文学习网 - HTML5先行者学习网
$new_height = $width / $ratio; 7jBHTML5中文学习网 - HTML5先行者学习网
$new_width = $width; 7jBHTML5中文学习网 - HTML5先行者学习网
} elseif ($crop && $ratio <= ($width / $height)) { 7jBHTML5中文学习网 - HTML5先行者学习网
$new_height = $width / $ratio; 7jBHTML5中文学习网 - HTML5先行者学习网
$new_width = $width; 7jBHTML5中文学习网 - HTML5先行者学习网
} else { 7jBHTML5中文学习网 - HTML5先行者学习网
$new_width = $height * $ratio; 7jBHTML5中文学习网 - HTML5先行者学习网
$new_height = $height; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
} else { 7jBHTML5中文学习网 - HTML5先行者学习网
$new_width = $w; 7jBHTML5中文学习网 - HTML5先行者学习网
$new_height = $h; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
$x_mid = $new_width * .5; //horizontal middle 7jBHTML5中文学习网 - HTML5先行者学习网
$y_mid = $new_height * .5; //vertical middle 7jBHTML5中文学习网 - HTML5先行者学习网
// Resample 7jBHTML5中文学习网 - HTML5先行者学习网
error_log('height: ' . $new_height . ' - width: ' . $new_width); 7jBHTML5中文学习网 - HTML5先行者学习网
$new = imagecreatetruecolor(round($new_width), round($new_height)); 7jBHTML5中文学习网 - HTML5先行者学习网
imagecopyresampled($new, $image, 0, 0, 0, 0, $new_width, $new_height, $w, $h); 7jBHTML5中文学习网 - HTML5先行者学习网
// Crop 7jBHTML5中文学习网 - HTML5先行者学习网
if ($crop) { 7jBHTML5中文学习网 - HTML5先行者学习网
$crop = imagecreatetruecolor($width ? $width : $new_width, $height ? $height : $new_height); 7jBHTML5中文学习网 - HTML5先行者学习网
imagecopyresampled($crop, $new, 0, 0, ($x_mid - ($width * .5)), 0, $width, $height, $width, $height); 7jBHTML5中文学习网 - HTML5先行者学习网
//($y_mid - ($height * .5)) 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
// Output 7jBHTML5中文学习网 - HTML5先行者学习网
// Enable interlancing [for progressive JPEG] 7jBHTML5中文学习网 - HTML5先行者学习网
imageinterlace($crop ? $crop : $new, true); 7jBHTML5中文学习网 - HTML5先行者学习网
$dext = strtolower(pathinfo($destination, PATHINFO_EXTENSION)); 7jBHTML5中文学习网 - HTML5先行者学习网
if ($dext == '') { 7jBHTML5中文学习网 - HTML5先行者学习网
$dext = $ext; 7jBHTML5中文学习网 - HTML5先行者学习网
$destination .= '.' . $ext; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
switch ($dext) { 7jBHTML5中文学习网 - HTML5先行者学习网
case 'jpeg': 7jBHTML5中文学习网 - HTML5先行者学习网
case 'jpg': 7jBHTML5中文学习网 - HTML5先行者学习网
imagejpeg($crop ? $crop : $new, $destination, $quality); 7jBHTML5中文学习网 - HTML5先行者学习网
break; 7jBHTML5中文学习网 - HTML5先行者学习网
case 'png': 7jBHTML5中文学习网 - HTML5先行者学习网
$pngQuality = ($quality - 100) / 11.111111; 7jBHTML5中文学习网 - HTML5先行者学习网
$pngQuality = round(abs($pngQuality)); 7jBHTML5中文学习网 - HTML5先行者学习网
imagepng($crop ? $crop : $new, $destination, $pngQuality); 7jBHTML5中文学习网 - HTML5先行者学习网
break; 7jBHTML5中文学习网 - HTML5先行者学习网
case 'gif': 7jBHTML5中文学习网 - HTML5先行者学习网
imagegif($crop ? $crop : $new, $destination); 7jBHTML5中文学习网 - HTML5先行者学习网
break; 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
@imagedestroy($image); 7jBHTML5中文学习网 - HTML5先行者学习网
@imagedestroy($new); 7jBHTML5中文学习网 - HTML5先行者学习网
@imagedestroy($crop); 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
} 7jBHTML5中文学习网 - HTML5先行者学习网
7jBHTML5中文学习网 - HTML5先行者学习网
PHP最终会返回一个JSON格式的数组,我返回的信息就是图片地址、名称,还有段img的html代码,最后在js那边获取到json数组并处理,至此,操作结束。 7jBHTML5中文学习网 - HTML5先行者学习网
文章最开始提到,还有点击选择文件上传和网络图片,因为这2个不属于这次的主题范围内,就不说了。况且这2个功能实现起来都不麻烦。 7jBHTML5中文学习网 - HTML5先行者学习网
demo下载7jBHTML5中文学习网 - HTML5先行者学习网
(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助