0
点赞
收藏
分享

微信扫一扫

EasyUI中拖动draggable的使用



效果

EasyUI中拖动draggable的使用_draggable

实现

在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>

效果

EasyUI中拖动draggable的使用_css_02

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>

效果

EasyUI中拖动draggable的使用_draggable_03

自定义拖动代理

<!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>

效果

EasyUI中拖动draggable的使用_css_04

限制区域拖动

新建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>

效果

EasyUI中拖动draggable的使用_html_05

限制范围拖动

举报

相关推荐

0 条评论