jquery简单的拖动效果

转自:https://www.oschina.net/code/snippet_590876_13891

<!DOCTYPE html>
<html>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>简单拖曵原理实例</title>
    <style type="text/css">
        #drag{width:400px;height:300px;background:url(http://upload.yxgz.cn/uploadfile/2009/0513/20090513052611873.jpg);cursor:move;position:absolute;top:100px;left:100px;border:solid 1px #ccc;}
        h2{color:#fff;background: none repeat scroll 0 0 rgba(16, 90, 31, 0.7);color:#FFFFFF;height:40px;line-height:40px;margin:0;}
    </style>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(function(){
            /*--------------拖曳效果----------------
            *原理:标记拖曳状态dragging ,坐标位置iX, iY
            *         mousedown:fn(){dragging = true, 记录起始坐标位置,设置鼠标捕获}
            *         mouseover:fn(){判断如果dragging = true, 则当前坐标位置 - 记录起始坐标位置,绝对定位的元素获得差值}
            *         mouseup:fn(){dragging = false, 释放鼠标捕获,防止冒泡}
            */
            var dragging = false;
            var iX, iY;
            $("#drag").mousedown(function(e) {
                dragging = true;
                iX = e.clientX - this.offsetLeft;
                iY = e.clientY - this.offsetTop;
                this.setCapture && this.setCapture();
                return false;
            });
            document.onmousemove = function(e) {
                if (dragging) {
                var e = e || window.event;
                var oX = e.clientX - iX;
                var oY = e.clientY - iY;
                $("#drag").css({"left":oX + "px", "top":oY + "px"});
                return false;
                }
            };
            $(document).mouseup(function(e) {
                dragging = false;
                $("#drag")[0].releaseCapture();
                e.cancelBubble = true;
            })
 
        })
 
    </script>
</head>
 
<body>
    <div id="drag">
        <h2>来拖动我啊</h2>
    </div>
</body>
</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery拖拽特效是利用jQuery库中的draggable()和droppable()方法实现的。draggable()方法用于使元素可以被拖拽,而droppable()方法用于定义元素可放置的目标区域。 要实现拖拽特效,首先需要在HTML中包含jQuery库的引用,然后编写相应的代码。 以下是一个简单的示例: 1. HTML代码: ```html <div id="draggable">可拖拽的元素</div> <div id="droppable">可放置的目标区域</div> ``` 2. JavaScript代码: ```javascript $(document).ready(function() { $("#draggable").draggable(); $("#droppable").droppable({ drop: function(event, ui) { $(this).addClass("dropped"); $(ui.draggable).addClass("dragged"); $(ui.draggable).detach().appendTo(this); } }); }); ``` 在上面的代码中,我们首先使用draggable()方法将id为"draggable"的元素设置为可拖拽的。接着使用droppable()方法将id为"droppable"的元素设置为可放置元素的目标区域。 在droppable()方法的参数中,我们定义了一个drop事件处理函数。当拖拽元素被放置到目标区域时,这个函数将被调用。在这个函数中,我们给目标区域添加了一个名为"dropped"的类,给拖拽元素添加了一个名为"dragged"的类并将拖拽元素移动到目标区域内。 最后,在CSS中定义类".dropped"和".dragged"的样式,以实现特定的外观效果。 完成以上步骤后,保存并加载页面,你将能够在页面上看到一个可拖拽的元素和一个可放置的目标区域。当你拖拽元素到目标区域时,目标区域会改变外观,并将拖拽元素放置在内部。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值