jq实现拖拽功能

基本思路:1.首先需要鼠标按下拖动区域,也就是需要调用mousedown方法

                 2.鼠标移动,需要拖动的元素跟着鼠标移动,调用mousemove方法

                 3.鼠标弹起拖动消失,调用mouseup方法

#a1{
			width:25px;
			height:25px;
			background:#a6e22e;
			cursor:pointer;
			position:absolute;
			left:0;
			top:0;
		}
<div id="a1">
   </div>
$(function(){
  

  $('#a1').mousedown(function(e){
    
    var positionDiv = $(this).offset();
    var distenceX = e.pageX - positionDiv.left;
    var distenceY = e.pageY - positionDiv.top;
    
    $(document).mousemove(function(e){
      var x = e.pageX - distenceX;
      var y = e.pageY - distenceY;
      if(x<0){
        x=0;
      }else if(x>$(document).width()-$('#a1').outerWidth(true)){
        x = $(document).width()-$('#a1').outerWidth(true);
      }
      if(y<0){
        y=0;
      }else if(y>$(document).height()-$('#a1').outerHeight(true)){
        y = $(document).height()-$('#a1').outerHeight(true);
      }
      $('#a1').css({
        'left':x+'px',
        'top':y+'px'
      });
    });
    $(document).mouseup(function(){
      $(document).off('mousemove');
    });
  });
});



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值