easyui Droppable组件实现放置特效


Posted in Javascript onAugust 19, 2015

所谓放置,就是将一个物体放入一个物体内,当然对于easyui来说触发各种效果是必不可少的,同时这个组件也不会依赖于其他组件。

Droppable的加载方式

1,class  加载   一直不太喜欢class方式的加载  浪费一个位置,代码一多还看着乱七八糟的。

<div id='dd' class="easyui-droppable" data-options="accept:'#box,#pox'"></div>

2,js 加载调用

$("#box").droppable({
  accept:'#pox',     //将元素pox 放置在元素box中
});

Droppable的属性

1,accept

默认为null,确定哪些元素被接受,也就是那个元素能被放置

$("#box").droppable({
  accept:'#pox',     //将元素pox 放置在元素box中
});

2,deisabled

默认为false   如果为true,则禁止放置

$("#box").droppable({
  accept:'#pox',     //将元素pox 放置在元素box中
  disabled : true ,    //禁止放置
});

Droppable 事件列表

1,onDragEnter  在被拖拽元素到放置区域内的时候触发

2,onDragOver 在被拖拽元素经过放置区域的时候触发

3,onDragLeave  在被拖拽元素离开放置区域的时候触发

4,onDrop  在被拖拽元素放入到放置区的时候触发

onDragEnter /onDragOver/onDragLeave/onDrop: function (e,source){
   //source 参数获取DOM元素
 }

Droppable 方法列表

1,options 返回属性对象

console.log($('#box').droppable('options'));

2,enable,disable 和上面属性的功能是一样的  分别是启用和禁止放置

$('#box').droppable('enable/disable')

给大家展示下官方的示例吧

<!DOCTYPE html>
<html>
<head>
 <meta charset="UTF-8">
 <title>Accept a Drop - jQuery EasyUI Demo</title>
 <link rel="stylesheet" type="text/css" href="jquery-easyui-1.3.6/themes/metro/easyui.css">
 <link rel="stylesheet" type="text/css" href="jquery-easyui-1.3.6/themes/icon.css">
 <link rel="stylesheet" type="text/css" href="jquery-easyui-1.3.6/demo/demo.css">
 <script type="text/javascript" src="jquery-easyui-1.3.6/jquery.min.js"></script>
 <script type="text/javascript" src="jquery-easyui-1.3.6/jquery.easyui.min.js"></script>
</head>
<body>
 <div style="margin:20px 0;"></div>
 <div id="source" style="border:1px solid #ccc;width:300px;height:400px;float:left;margin:5px;">
  drag me!
  <div id="d1" class="drag">Drag 1</div>
  <div id="d2" class="drag">Drag 2</div>
  <div id="d3" class="drag">Drag 3</div>
 </div> 
 <div id="target" style="border:1px solid #ccc;width:300px;height:400px;float:left;margin:5px;">
  drop here!
 </div>
 <div style="clear:both"></div>
 <style type="text/css">
  .drag{
   width:100px;
   height:50px;
   padding:10px;
   margin:5px;
   border:1px solid #ccc;
   background:#AACCFF;
  }
  .dp{
   opacity:0.5;
   filter:alpha(opacity=50);
  }
  .over{
   background:#FBEC88;
  }
 </style>
 <script>
  /**
  使用js方式将元素设置为可draggable的
  */
  $(function(){
   $('.drag').draggable({
    proxy:'clone',
    revert:true,
    cursor:'pointer',
    onStartDrag:function(){
     $(this).draggable('options').cursor='not-allowed';//设置鼠标样式为不可拖动
     $(this).draggable('proxy').addClass('dp');//设置样式
    },
    onStopDrag:function(){
     $(this).draggable('options').cursor='auto';//设置鼠标
    }
   });
   //将容易置为droppable并且可接受元素
   $('#target').droppable({
    accept:'#d1,#d3',
    onDragEnter:function(e,source){//拖入
     $(source).draggable('options').cursor='auto';
     $(source).draggable('proxy').css('border','1px solid red');
     $(this).addClass('over');
    },
    onDragLeave:function(e,source){//脱离
     $(source).draggable('options').cursor='not-allowed';
     $(source).draggable('proxy').css('border','1px solid #ccc');
     $(this).removeClass('over');
    },
    onDrop:function(e,source){//放下
     $(this).append(source)
     $(this).removeClass('over');
     alert("我被放下了");
    } ,
    //onDropOver当元素被拖出(成功放入到某个容器)的时候触发
    onDragOver:function(e,source){
      alert("我被拖出去了");//先于alert("我被放下了");执行,表明其触发在onDrop之前。
   }
   });
  });
 </script>
 
</body>
</html>

          运行效果图这里就不给出了,官网直接就可以查看。OVER!

          效果地址: http://www.jeasyui.com/demo/main/index.php?plugin=Droppable&theme=default&dir=ltr&pitem=

easyui 1.3.5 Droppable 就此完结。

Javascript 相关文章推荐
一段实时更新的时间代码
Jul 07 Javascript
JS 图片缩放效果代码
Jun 09 Javascript
JavaScript内核之基本概念
Oct 21 Javascript
IE8下jQuery改变png图片透明度时出现的黑边
Aug 30 Javascript
jQuery实现的checkbox级联选择下拉菜单效果示例
Dec 26 Javascript
微信小程序 chooseImage选择图片或者拍照
Apr 07 Javascript
Vue.js中extend选项和delimiters选项的比较
Jul 17 Javascript
bootstrap table方法之expandRow-collapseRow展开或关闭当前行数据
Aug 09 Javascript
详谈commonjs模块与es6模块的区别
Oct 18 Javascript
使用angular-cli webpack创建多个包的方法
Oct 16 Javascript
JS使用对象的defineProperty进行变量监控操作示例
Feb 02 Javascript
前端开发之便利店收银系统代码
Dec 27 Javascript
js实现简单的联动菜单效果
Aug 19 #Javascript
javascript 使用for循环时该注意的问题-附问题总结
Aug 19 #Javascript
jQuery满意度星级评价插件特效代码分享
Aug 19 #Javascript
easyui Draggable组件实现拖动效果
Aug 19 #Javascript
使用CamanJS在Web页面上处理图像的技巧
Aug 18 #Javascript
JS实现下拉菜单赋值到文本框的方法
Aug 18 #Javascript
JS实现可调整倒计时间代码分享
Aug 18 #Javascript
You might like
CentOS安装php v8js教程
2015/02/26 PHP
php使用memcoder将视频转成mp4格式的方法
2015/03/12 PHP
浅谈PHP中的面向对象OOP中的魔术方法
2017/06/12 PHP
PHP 实现页面静态化的几种方法
2017/07/23 PHP
Laravel框架在本地虚拟机快速安装的方法详解
2018/06/11 PHP
PHP设计模式之装饰器模式定义与用法简单示例
2018/08/13 PHP
PHP中16个高危函数整理
2019/09/19 PHP
JQuery 无废话系列教程(一) jquery入门 [推荐]
2009/06/23 Javascript
一行代码告别document.getElementById
2012/06/01 Javascript
artDialog双击会关闭对话框的修改过程分享
2013/08/05 Javascript
jquery引用方法时传递参数原理分析
2014/10/13 Javascript
JS实现漂亮的时间选择框效果
2016/08/20 Javascript
React学习之事件绑定的几种方法对比
2017/09/24 Javascript
浅析node Async异步处理模块用例分析及常用方法介绍
2017/11/17 Javascript
vue-cli 默认路由再子路由选中下的选中状态问题及解决代码
2018/09/06 Javascript
JS 封装父页面子页面交互接口的实例代码
2019/06/25 Javascript
js实现滑动进度条效果
2020/08/21 Javascript
vue-drawer-layout实现手势滑出菜单栏
2020/11/19 Vue.js
python正则表达式修复网站文章字体不统一的解决方法
2013/02/21 Python
Python Tkinter GUI编程入门介绍
2015/03/10 Python
python定时复制远程文件夹中所有文件
2019/04/30 Python
如何使用python3获取当前路径及os.path.dirname的使用
2019/12/13 Python
Python+appium框架原生代码实现App自动化测试详解
2020/03/06 Python
Python 实现 T00ls 自动签到脚本代码(邮件+钉钉通知)
2020/07/06 Python
HTML5打开手机扫码功能及优缺点
2017/11/27 HTML / CSS
外贸公司实习自我鉴定
2013/09/24 职场文书
大客户销售经理职责
2013/12/04 职场文书
社区道德讲堂实施方案
2014/03/21 职场文书
弘扬雷锋精神演讲稿
2014/05/10 职场文书
运动会口号16字
2014/06/07 职场文书
送温暖献爱心活动总结
2014/07/08 职场文书
司机岗位职责说明书
2014/07/29 职场文书
2014年药店店长工作总结
2014/11/17 职场文书
安装工程师岗位职责
2015/02/13 职场文书
职工宿舍管理制度
2015/08/05 职场文书
如何起草一份正确的合伙创业协议书?
2019/07/04 职场文书