zoukankan      html  css  js  c++  java
  • js实现图片拖动改变顺序

    在web页面中,须要改变多个元素的位置,能够通过元素拖动来实现。HTML5中增加了一个全局属性draggable。通过设置true/false来控制元素是否可拖动。

    以下以图片拖动为例,用jQuery来实现:页面上有多个图片,把一个图片拖动到其它两个图片中间,就能够将这个图片的位置插入到两图之间。

    <!DOCTYPE html>
    <html>
    <head>
    <style>
    	.img-div img {
    		200px;
    		height:200px;
    		float: left;
    	}
    	.img-div {
    		float: left;
    	}
    	.drop-left,.drop-right {
    		 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元素放在图片的左右側,用于接收其它图片拖动到这个位置。




    作者:叉叉哥   转载请注明出处:http://blog.csdn.net/xiao__gui/article/details/25695025



  • 相关阅读:
    看我如何破解一台自动售货机
    充满未来和科幻的界面设计FUI在国内还没有起步在国外早起相当成熟
    libuv之介绍
    纯净版xp系统在局域网共享需要密码如何解决
    xp局域网共享设置
    Qt5设置应用程序图标
    我们为什么以及是如何从 Angular.js 迁移到 Vue.js?
    [转]聊聊技术选型
    VueJS如何引入css或者less文件的一些坑
    tomcat启动不成功(点击startup.bat闪退)的解决办法
  • 原文地址:https://www.cnblogs.com/wgwyanfs/p/7224146.html
Copyright © 2011-2022 走看看