以前写过一个原生JS的拖拽效果《原生JS拖拽效果》,今天闲来无事就写一个JQ的拖拽吧。
先上HTML部分:
<div class="boxbox"> <div class="box" style="top:150px;left:150px;"><em>关闭</em><img src="http://cenggel.com/wp-content/uploads/2018/07/20180723-01.png" /></div> <div class="box" style="top:310px;left:150px;"><em>关闭</em><img src="http://cenggel.com/wp-content/uploads/2018/07/2018071901.png" /></div> <div class="box" style="top:470px;left:150px;"><em>关闭</em><img src="http://cenggel.com/wp-content/uploads/2018/07/20180714-01.png" /></div> </div>
CSS部分:(www.gendan5.com)
<style> *{ padding:0; margin:0;} .boxbox{ margin: 0px auto; width: 1200px; height: 800px; position: relative; background: #eee;} .box{ position:absolute;} .box img{ display:block; height:150px; width:150px; cursor: all-scroll;} .box em{ position:absolute; top:0; right:0; padding:0 5px; display:block; float:right; cursor:pointer;} .box em:hover{ color:red;} </style>
JQ部分:
function CglDrag(mainbox,Subgrade) { //按钮及初始值 var disX = 0, disY = 0, zindex = 10;
$(document).on('mousedown',Subgrade,function (ev) {
var _thiss = $(this);
//用于提高当前的z-index值
zindex++;
_thiss.css('z-index',zindex)
//边界计算 - 有这个的时候被拖拽的盒子不能超过他的父级
function xianzhi(val,max,min){
if (val > max){
return max;
}else if(val < min){
return min;
}else{
return val;
}
}
//获取XY值
var ev = ev || window.event;
disX = ev.clientX - _thiss.get(0).offsetLeft;
disY = ev.clientY - _thiss.get(0).offsetTop;
//鼠标按下的时候
$(document).mousemove(function () {
var ev = ev || window.event;
var lefts= (ev.clientX - disX),
tops= (ev.clientY - disY),
maxle= ( _thiss.parent(mainbox).width() - _thiss.get(0).offsetWidth),
maxto= ( _thiss.parent(mainbox).height() - _thiss.get(0).offsetHeight)
lefts = xianzhi(lefts,maxle,0)
tops = xianzhi(tops,maxto,0)
_thiss.get(0).style.left = lefts + 'px';
_thiss.get(0).style.top = tops + 'px';
_thiss.find('img').attr('data-left',lefts)
_thiss.find('img').attr('data-top',tops)
});
//鼠标松开的时候
$(document).mouseup(function () {
$(document).unbind('mousemove')
$(document).unbind('mouseup')
});
//点击em移除
$(this).find('em').click(function () {
$(this).parent('div').remove();
});
return false;
});
};
//引用 第一个参数:父级 第二个参数:自己 CglDrag('.boxbox','.box');
一个JQuery拖拽效果就这样出来了。