js实现图片拖动改变顺序
2014-05-13 11:06
561 查看
在web页面中,需要改变多个元素的位置,可以通过元素拖动来实现。HTML5中加入了一个全局属性draggable,通过设置true/false来控制元素是否可拖动。
下面以图片拖动为例,用jQuery来实现:页面上有多个图片,把一个图片拖动到其他两个图片中间,就可以将这个图片的位置插入到两图之间。
dragstart是开始拖动元素的事件,dragover是拖动到元素上方的事件,drop是拖动结束松开鼠标的事件。
draggable="true"表示img元素是可以拖动的,不过实际上img默认就是可拖动的,所以这个属性也可以去掉,如果要拖动div元素那么就需要设置draggable="true"。
class为drop-left和drop-right的div元素放在图片的左右侧,用于接收其他图片拖动到这个位置。
作者:叉叉哥 转载请注明出处:/article/1557551.html
下面以图片拖动为例,用jQuery来实现:页面上有多个图片,把一个图片拖动到其他两个图片中间,就可以将这个图片的位置插入到两图之间。
<!DOCTYPE html> <html> <head> <style> .img-div img { width:200px; height:200px; float: left; } .img-div { float: left; } .drop-left,.drop-right { width: 50px; height: 200px; float: left; } </style> <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.0/jquery.min.js"></script> <script> $(document).ready(function() { // 正在拖动的图片的父级DIV var $srcImgDiv = null; // 开始拖动 $(".img-div img").bind("dragstart", function() { $srcImgDiv = $(this).parent(); }); // 拖动到.drop-left,.drop-right上方时触发的事件 $(".drop-left,.drop-right").bind("dragover", function(event) { // 必须通过event.preventDefault()来设置允许拖放 event.preventDefault(); }); // 结束拖动放开鼠标的事件 $(".drop-left").bind("drop", function(event) { event.preventDefault(); if($srcImgDiv[0] != $(this).parent()[0]) { $(this).parent().before($srcImgDiv); } }); $(".drop-right").bind("drop", function(event) { event.preventDefault(); if($srcImgDiv[0] != $(this).parent()[0]) { $(this).parent().after($srcImgDiv); } }); }); </script> </head> <body> <div class="img-div"> <div class="drop-left"></div> <img src="http://photos.tuchong.com/38538/f/6864556.jpg" draggable="true"> <div class="drop-right"></div> </div> <div class="img-div"> <div class="drop-left"></div> <img src="http://photos.tuchong.com/349669/f/6695960.jpg" draggable="true"> <div class="drop-right"></div> </div> <div class="img-div"> <div class="drop-left"></div> <img src="http://photos.tuchong.com/349669/f/6683901.jpg" draggable="true"> <div class="drop-right"></div> </div> <div class="img-div"> <div class="drop-left"></div> <img src="http://photos.tuchong.com/349669/f/5121337.jpg" draggable="true"> <div class="drop-right"></div> </div> </body> </html>
dragstart是开始拖动元素的事件,dragover是拖动到元素上方的事件,drop是拖动结束松开鼠标的事件。
draggable="true"表示img元素是可以拖动的,不过实际上img默认就是可拖动的,所以这个属性也可以去掉,如果要拖动div元素那么就需要设置draggable="true"。
class为drop-left和drop-right的div元素放在图片的左右侧,用于接收其他图片拖动到这个位置。
作者:叉叉哥 转载请注明出处:/article/1557551.html
相关文章推荐
- js实现图片拖动改变顺序附图
- javascript完美实现图片拖动改变顺序
- js实现点击图片改变页面背景图的方法
- 【荐】JS实现的图片弹性拖动特效代码
- JS实现拖动图片
- JS实现动态改变对话窗口和图片样式的聊天;
- JS实现拖动div改变大小
- js通过八个点 拖动改变div大小的实现方法
- js实现左侧边栏可拖动改变显示区域宽度
- 超简短JS实现下拉菜单改变网页背景图片
- [转] js 实现table每列可左右拖动改变列宽度
- OL3中结合Jquery UI实现图层拖动并改变图层顺序
- OL3中结合Jquery UI实现图层拖动并改变图层顺序
- JS实现拖动元素分界改变元素大小
- js实现鼠标拖动图片并兼容IE/FF火狐/谷歌等主流浏览器
- Android编程实现支持拖动改变位置的图片中叠加文字功能示例
- node-webkit学习之【无边框窗口用JS实现拖动改变大小等】
- 使用ASP.NET AJAX Control Toolkit中的ReorderList控件实现用鼠标拖动改变条目顺序
- js实现点击图片改变页面背景图的方法