EasyUI中拖动draggable的使用

场景

EasyUI环境搭建与入门基础语法:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/90760947

效果

实现

在webapp下新建pages目录,在pages目录下新建draggable目录,并在其下新建basic.html

通过class属性实现

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拖拽</title>
    <link rel="stylesheet" type="text/css" href="/easyui/themes/default/easyui.css">
    <link rel="stylesheet" type="text/css" href="/easyui/themes/icon.css">
    <script type="text/javascript" src="/easyui/jquery.min.js"></script>
    <script type="text/javascript" src="/easyui/jquery.easyui.min.js"></script>
</head>
<body>
    <div  class="easyui-draggable" style="width:300px; height:300px; border:1px solid #ccc">
        可拖拽
    </div>
</body>
</html>

通过js实现

    <div  id="drag" style="width:300px; height:300px; border:1px solid #ccc">
        通过js实现可拖拽
    </div>
<script type="text/javascript">
        $(function () {
            $("#drag").draggable();
        })
</script>

局部区域拖动

实现拖动局部才能拖动,比如标题。

通过handle属性实现,其中属性值为要局部拖动的选择器。

<div  id="dragTitle" class="easyui-draggable" style="width:300px; height:300px; border:1px solid #ccc" handle="#title">
        <div id="title" style="background-color: #CC2222">标题拖动</div>
 </div>

效果

js初始化拖动代理

新建proxy.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拖动代理</title><link rel="stylesheet" type="text/css" href="/easyui/themes/default/easyui.css">
    <link rel="stylesheet" type="text/css" href="/easyui/themes/icon.css">
    <script type="text/javascript" src="/easyui/jquery.min.js"></script>
    <script type="text/javascript" src="/easyui/jquery.easyui.min.js"></script>

</head>
<body>
<div  id="dragProxy" style="width:300px; height:300px; border:1px solid #ccc">
    js初始化拖动代理
</div>
<script type="text/javascript">
    $(function () {
        $("#dragProxy").draggable({
            proxy:"clone"
        });
    })
</script>
</body>
</html>

效果

自定义拖动代理

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>拖动代理</title><link rel="stylesheet" type="text/css" href="/easyui/themes/default/easyui.css">
    <link rel="stylesheet" type="text/css" href="/easyui/themes/icon.css">
    <script type="text/javascript" src="/easyui/jquery.min.js"></script>
    <script type="text/javascript" src="/easyui/jquery.easyui.min.js"></script>

</head>
<body>
<div  id="dragProxy" style="width:300px; height:300px; border:1px solid #ccc">
    js初始化拖动代理
</div>
<script type="text/javascript">
    $(function () {
        $("#dragProxy").draggable({
            proxy:function(source){
                var p =$("<div  style='width:300px; height:300px; border:1px solid red'>");
                p.appendTo("body");
                return p;
            }
        });
    })
</script>
</body>
</html>

效果

限制区域拖动

新建container.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>限制区域拖动</title>
    <link rel="stylesheet" type="text/css" href="/easyui/themes/icon.css">
    <script type="text/javascript" src="/easyui/jquery.min.js"></script>
    <script type="text/javascript" src="/easyui/jquery.easyui.min.js"></script>
</head>
<body>
<div   style="width:300px; height:300px; border:1px solid #ccc" >
    <div id="container" style="width:100px; height:100px;background-color: #CC2222"></div>
</div>
<script type="text/javascript">
    $(function () {
        $("#container").draggable({
            //onDrag为拖动事件
           onDrag:function (e) {
               var d = e.data;
               //如果拖动到最左边
               if(d.left<d.parent.offsetLeft){
                   d.left=d.parent.offsetLeft;
               }
               //如果拖动到最上边
               if(d.top<d.parent.offsetTop){
                   d.top=d.parent.offsetTop;
               }
               if(d.left+$(d.target).outerWidth()>$(d.parent).outerWidth()+d.parent.offsetLeft){
                   d.left=$(d.parent).outerWidth()-$(d.target).outerWidth()+d.parent.offsetLeft;
               }
               if(d.top+$(d.target).outerHeight()>$(d.parent).outerHeight()+d.parent.offsetTop){
                   d.top=$(d.parent).outerHeight()-$(d.target).outerHeight()+d.parent.offsetTop;
               }
           }
        });
    })
</script>
</body>
</html>

效果

限制范围拖动

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

霸道流氓气质

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值