件拖拽上传
使用HTML5的文件API, 可以将操作系统中的文件拖放到浏览器的指定区域, 实现文件上传到服务器。本文将结合实例讲解HTML5+jQuery+PHP实现拖拽上传图片的过程, 来看下HTML5的魅力吧。
HTML
我们在页面中放置一个拖拽区域#drop_area, 即接收拖拽的区域, #preview用来预览拖拽上传的图片信息。
<div id="drop_area">将图片拖拽到此区域</div>
<div id="preview"></div>
Javascript
要想实现拖拽, 页面需要阻止浏览器默认行为, 即四个事件(拖离、拖后放、拖进、拖来拖去), 因为我们要阻止浏览器默认将图片打开的行为, 这里我们使用jQuery来完成。
$(function(){
//阻止浏览器默认行。
$(document).on({
dragleave:function(e){ //拖离
e.preventDefault();
},
drop:function(e){ //拖后放
e.preventDefault();
},
dragenter:function(e){ //拖进
e.preventDefault();
},
dragover:function(e){ //拖来拖去
e.preventDefault();
}
});
...
});
接下来我们来了解下文件API。HTML5的文件API有一个FileList接口, 它可以通过e.dataTransfer.files拖拽事件传递的文件信息, 获取本地文件列表信息
var fileList = e.dataTransfer.files;
在本例中, 我们用javascript来侦听drop事件, 首先要判断拖入的文件是否符合要求, 包括图片类型、大小等, 然后获取本地图片信息, 实现预览, 最后上传。
$(function(){
/// ...接上部分
var box = document.getElementById('drop_area'); //拖拽区域
box.addEventListener("drop",function(e){
e.preventDefault(); //取消默认浏览器拖拽效果
var fileList = e.dataTransfer.files; //获取文件对象
//检测是否是拖拽文件到页面的操作
if(fileList.length == 0){
return false;
}
//检测文件是不是图片
if(fileList[0].type.indexOf('image') === -1){
alert("您拖的不是图片!");
return false;
}
//拖拉图片到浏览器,可以实现预览功能
var img = window.URL.createObjectURL(fileList[0]);
var filename = fileList[0].name; //图片名称
var filesize = Math.floor((fileList[0].size)/1024);
if(filesize>500){
alert("上传大小不能超过500K.");
return false;
}
var str = "<img src='"+img+"'><p>图片名称:"+filename+"</p><p>大小:"+filesize+"KB</p>";
$("#preview").html(str);
//上传
xhr = new XMLHttpRequest();
xhr.open("post", "upload.php", true);
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
var fd = new FormData();
fd.append('mypic', fileList[0]);
xhr.send(fd);
},false);
});
我们用FormData模拟表单数据, 直接将数据append到formdata对象中, 实现了ajax上传。
PHP
upload.php用于接收上传的文件信息, 完成上传, 实现代码如下:
<?php
$mypic = $_FILES["mypic"];
if(!empty($mypic)){
$picname = $_FILES['mypic']['name'];
$picsize = $_FILES['mypic']['size'];
if ($picsize > 512000) {
echo '图片大小不能超过500k';
exit;
}
$type = strstr($picname, '.');
if ($type != ".gif" && $type != ".jpg") {
echo '图片格式不对!';
exit;
}
$pics = 'helloweba' . $type;
//上传路径
$pic_path = "pics/". $pics;
move_uploaded_file($mypic["tmp_name"],$pic_path);
}
?>
下边这几句可以没有
<meta charset="utf-8">
<form action="" method="post" enctype="multipart/form-data">
<input type="file" name="mypic">
<input type="submit" value="上传">
</form>
最后总结下HTML5实现拖拽上传的技术要点:
1、监听拖拽:监听页面元素的拖拽事件, 包括:dragenter、dragover、dragleave和drop, 一定要将dragover的默认事件取消掉, 不然无法触发drop事件。如需拖拽页面里的元素, 需要给其添加属性draggable=”true”;
2、获取拖拽文件:在drop事件触发后通过e.dataTransfer.files获取拖拽文件列表, .length属性获取文件数量, .type属性获取文件类型。
3、读取图片数据并添加预览图。
4、发送图片数据:使用FormData模拟表单数据AJAX提交文件流。
言
实现炫酷的的拖行拖拽
1.需求分析:设计一个元素,可以跟随鼠标的移动,元素也进行移动,并且能够在鼠标按上与按下元素的时候,元素可以进行改变样式颜色。
2. 设计思路:先是需要获取元素,给元素绑定鼠标按下的事件,在绑定的事件中,兼容event事件,获取鼠标的坐标和元素的坐标,通过鼠标的坐标减去元素的坐标就可以得到鼠标在元素中的坐标。在绑定事件中,写上一个元素的移动事件,获取元素的移动坐标。最后,在鼠标按上的事件函数中,可以调用元素的移动事件就可以了。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>图层拖拽</title> <style> .box { width: 200px; height: 200px; background-color: skyblue; border: 2px solid #ccc; cursor: pointer; position: absolute; top: 20px; left: 100px; } </style> </head> <body> <div class="box" id="box"></div> </body> <script> var box = document.getElementById("box"); box.onmousedown = function(env){ // 兼容event事件 var env = env || window.event; // 获取鼠标的坐标 var x = env.clientX; var y = env.clientY; // 获取元素的坐标 var left = box.offsetLeft; var top = box.offsetTop; // 获取鼠标在元素中的坐标 var x_left = x - left; var y_top = y -top; // 鼠标点击后改变颜色 box.style.background = "red"; // 元素的移动事件函数 box.onmousemove = function(env){ // 兼容event事件 var env = env || window.event; // 获取元素移动时的鼠标的坐标 var x = env.clientX; var y = env.clientY; // 元素的移动坐标 box.style.left = (x - x_left)+"px"; box.style.top = (y - y_top)+"px"; } }; // 鼠标弹出的事件函数 box.onmouseup = function(){ box.style.background = "skyblue"; // 在鼠标弹出后再次调用元素的鼠标移动事件 box.onmousemove = function(){}; }; </script> </html>
学习从来不是一个人的事情,要有个相互监督的伙伴,想要学习或交流前端问题的小伙伴可以私信回复小明“学习” 获取资料,一起学习!
什么是拖拽?
本质上来说就是一个对象和一个对象直接传递。
其实学习拖拽,就是学习拖拽事件。
⒉在HTML5中很多元素是不能进行拖拽的,比如说图片和超链接:
在试图拖拽时你会发现一个禁止的符号,如果想拖拽元素,就必须为元素添加draggable="true"。
⒊相关的事件
应用于被拖拽元素的事件
ondrag 应用于拖拽元素,整个拖拽过程都会调用--持续
ondragstart 应用于拖拽元素,当拖拽开始时调用
ondragleave 应用于拖拽元素,当鼠标离开拖拽元素时调用
ondragend 应用于拖拽元素,当拖拽结束时调用
应用于目标元素的事件
ondragenter 应用于目标元素,当拖拽元素进入时调用
ondragover 应用于目标元素,当停留在目标元素上时调用
ondrop 应用于目标元素,当在目标元素上松开鼠标时调用
ondragleave 应用于目标元素,当鼠标离开目标元素时调用
案例:
注意:如果想触发ondrop事件,那么就必须在ondragover事件中阻止浏览器的默认行为。
来源网络,侵权联系删除
私信我或关注微信号:猿来如此呀,回复:学习,获取免费学习资源包。
*请认真填写需求信息,我们会在24小时内与您取得联系。