本文摘自PHP中文网,作者php中世界最好的语言,侵删。
这次给大家带来H5实现拖拉上传文件,H5实现拖拉上传文件的注意事项有哪些,下面就是实战案例,一起来看一下。在HTML5的pc上面实现了相当多的功能,工作中也用到了拖拉上传,特地记录下该功能
在拖动目标上触发事件 (源元素):
ondragstart - 用户开始拖动元素时触发
ondrag - 元素正在拖动时触发
ondragend - 用户完成元素拖动后触发
释放目标时触发的事件:
ondragenter - 当被鼠标拖动的对象进入其容器范围内时触发此事件
ondragover - 当某被拖动的对象在另一对象容器范围内拖动时触发此事件
ondragleave - 当被鼠标拖动的对象离开其容器范围内时触发此事件
ondrop - 在一个拖动过程中,释放鼠标键时触发此事件
上代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | <html lang= "en" >
<head>
<meta charset= "UTF-8" >
<title>拖拽</title>
<style>
.box{width:800px;height:600px;float:left;}
#box1{background-color:#ccc;}
#box2{background-color:#000;}
</style>
</head>
<body>
<p id= "box1" class = "box" ></p>
<p id= "box2" class = "box" ></p>
<img id= "img1" src= "1.jpg" >
<p id= "msg" ></p>
</body>
<script>
var box1p,box2p,msgp,img1;
window.onload = function (){
box1p = document.getElementById( 'box1' );
box2p = document.getElementById( 'box2' );
msgp = document.getElementById( 'msg' );
img1 = document.getElementById( 'img1' );
box1p.ondragover = function (e){e.preventDefault();}
box2p.ondragover = function (e){e.preventDefault();}
img1.ondragstart = function (e){e.dataTransfer.setData( 'imgId' , 'img1' );}
box1p.ondrop = dropImghandler;
box2p.ondrop = dropImghandler;
}
function dropImghandler(e){
showObj(e);
showObj(e.dataTransfer);
e.preventDefault();
var img = document.getElementById(e.dataTransfer.getData( 'imgId' ));
e.target.appendChild(img);
}
function showObj(obj){
var s = '' ;
for ( var k in obj){s += k+ ":" +obj[k]+ "<br/>" ;}
msgp.innerHTML = s;
}
</script>
</html>
|
该功能是可以将图片拖拉到左右两个p中的方法,我觉得没啥用,可以当作哈啤
下面是拖拉上传代码,后端PHP获取到$_FILES之后就可以搞起来了
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 | <!DOCTYPE html>
<html lang= "en" >
<head>
<meta charset= "UTF-8" >
<title>拖放上传</title>
<style>
#imgContainer{background:#ccc;width:500px;height:500px;}
</style>
</head>
<body>
<p id= "imgContainer" ></p>
<p id= "msg" ></p>
</body>
<script>
var imgContainer,msgp;
window.onload = function (e){
imgContainer = document.getElementById( 'imgContainer' );
msgp = document.getElementById( 'msg' );
imgContainer.ondragover = function (e){
e.preventDefault();
}
imgContainer.ondrop = function (e){
e.preventDefault();
var f = e.dataTransfer.files[0];
}
}
function showObj(obj){
var s = '' ;
for ( var k in obj){s += k+ ":" +obj[k]+ "<br/>" ;}
msgp.innerHTML = s;
}
</script>
</html>
|
相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!
推荐阅读:
H5如何使用约束验证API
postMessage实现跨域、跨窗口消息传递
以上就是H5实现拖拉上传文件的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
HTML5元素拖拽drag与拖放drop相关api的具体介绍(图文)
深入了解HTML5之sessionstorage对象
h5缓存-manifest的示例代码分享(图文)
h5的filereader怎样分布读取文件
HTML5转义实体字符的使用详解
详解HTML5应用中accordion三种效果的探索
HTML5 什么是prefetch/prerender?介绍HTML5 中prefetch/prerender
怎样开发优秀的HTML5游戏-迪斯尼《寻找奥兹之路》游戏技术详解(一)
HTML5 学习filereader接口代码实例分享9(图)
h5的filereader分布读取文件应该如何使用以及其方法简介
更多相关阅读请进入《HTML5》频道 >>
人民邮电出版社
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者
转载请注明出处:木庄网络博客 » H5实现拖拉上传文件