news 2026/4/16 12:33:29

jQuery EasyUI 拖放 - 基本的拖动和放置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery EasyUI 拖放 - 基本的拖动和放置

jQuery EasyUI 拖放 - 基本的拖动和放置

jQuery EasyUI提供了draggable(可拖动)和droppable(可放置)插件,实现基本的拖放(Drag and Drop)功能。这些插件允许用户通过鼠标拖动元素,并放置到指定区域,常用于交互式界面如排序、购物车等。

本教程演示最基本的拖放:创建几个可拖动的方块,并定义一个放置区域。当拖动元素放入放置区时,显示提示并改变样式。

官方参考:

  • 基本拖放教程:https://www.jeasyui.com/tutorial/dd/dnd1.php
  • Draggable 文档:https://www.jeasyui.com/documentation/draggable.php
  • Droppable 文档:https://www.jeasyui.com/documentation/droppable.php
  • 在线 Demo:https://www.jeasyui.com/tutorial/dd/dnd1_demo.html
步骤 1: 引入 EasyUI 资源
<linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/default/easyui.css"><linkrel="stylesheet"type="text/css"href="https://www.jeasyui.com/easyui/themes/icon.css"><scripttype="text/javascript"src="https://code.jquery.com/jquery-1.12.4.min.js"></script><scripttype="text/javascript"src="https://www.jeasyui.com/easyui/jquery.easyui.min.js"></script>
步骤 2: 创建 HTML 结构

创建三个可拖动元素(div)和一个放置区域。

<divid="dd1"class="dd-demo">Draggable 1</div><divid="dd2"class="dd-demo">Draggable 2</div><divid="dd3"class="dd-demo">Draggable 3</div><divid="drop"class="dd-drop">Drop here</div><style>.dd-demo{width:100px;height:100px;background:#fafafa;border:1px solid #ccc;margin:10px;padding:20px;text-align:center;float:left;cursor:move;}.dd-drop{width:300px;height:200px;background:#fff;border:2px dashed #ccc;margin:50px auto;text-align:center;line-height:200px;font-size:20px;clear:both;}.over{border:2px dashed #000;background:#ff0;}</style>
步骤 3: JavaScript 实现拖动和放置

使用.draggable()使元素可拖动,使用.droppable()定义放置区,并处理事件。

<scripttype="text/javascript">$(function(){// 使三个 div 可拖动$('#dd1').draggable({revert:true,// 未放入有效区时回弹proxy:'clone'// 拖动时显示克隆代理(可选)});$('#dd2').draggable({revert:true,cursor:'move',handle:null// 整个元素都可拖动});$('#dd3').draggable({revert:true,proxy:function(source){varp=$('<div class="proxy">Proxy</div>');p.html($(source).html()).appendTo('body');returnp;}// 自定义代理元素});// 定义放置区$('#drop').droppable({accept:'.dd-demo',// 只接受 .dd-demo 类的元素onDragEnter:function(e,source){$(this).addClass('over');// 拖入时高亮},onDragLeave:function(e,source){$(this).removeClass('over');// 拖出时恢复},onDrop:function(e,source){$(this).removeClass('over');$(this).append(source);// 将拖动元素追加到放置区$(this).html('Dropped! '+$(source).html());}});});</script>
关键说明
  • draggable选项:
    • revert: true:如果未放入有效 droppable,回弹到原位。
    • proxy: 'clone':拖动时显示克隆副本,原元素不动。
    • proxy: function:自定义代理显示。
  • droppable事件:
    • onDragEnter/onDragLeave:拖入/拖出时改变样式,提供视觉反馈。
    • onDrop:放置成功时执行操作(如追加元素、更新数据)。
    • accept:限制只接受特定选择器的 draggable。
  • 视觉效果:拖动时元素有半透明代理,放置区有高亮反馈。
运行效果
  • 用户可以拖动三个方块。
  • 当拖入放置区时,边框变黑并背景变黄。
  • 放置后,方块被追加到放置区,并显示 “Dropped!” 消息。

更多高级应用:

  • 拖放购物车:https://www.jeasyui.com/tutorial/dd/dnd2.php
  • 拖放课程表:https://www.jeasyui.com/tutorial/dd/dnd3.php

如果需要完整源码、自定义代理效果、或结合 datagrid/tree 的拖放示例,请提供更多细节!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 9:02:40

8、硬件与软件RAID构建全解析

硬件与软件RAID构建全解析 1. 硬件考量 在计算机硬件配置中,有几个关键的硬件因素需要我们仔细考虑,尤其是在涉及到存储系统时。 1.1 单连接器附件(SCA) 为了方便热插拔磁盘,IBM为SCSI硬盘引入了单连接器附件(SCA)。SCA将数据传输、电源和可配置选项(如SCSI ID)集…

作者头像 李华
网站建设 2026/4/16 9:06:43

从事网络安全需要高学历吗,说下我自己的看法

这几天有兄弟私聊我&#xff0c;问我从事网安方面的工作不需要学历吗&#xff1f;身边很多人都说学网安没必要到研究生。 我说下自己的一些看法吧。 目前来说确实很多从事安全行业的人员学历比较低&#xff0c;上次公众号做了一个调查&#xff0c;结果50%左右是本科以下学历。但…

作者头像 李华
网站建设 2026/4/15 13:05:48

【Linux 基础知识系列:第二百零二篇】网络端口转发工具:socat

一、简介&#xff1a;为什么必须掌握 socat&#xff1f;netcat 老了&#xff1a;nc 不支持 IPv6、SSL、fork 并发、串口参数细粒度控制&#xff0c;项目 2007 后基本停更。socat 持续进化&#xff1a;支持 100 协议与机制&#xff0c;官方称“Socket CAT——把任何双端数据流拼…

作者头像 李华
网站建设 2026/4/16 9:02:17

LobeChat蓝绿部署实施方案

LobeChat 蓝绿部署实施方案 在当今 AI 应用快速迭代的背景下&#xff0c;如何在不中断服务的前提下完成系统升级&#xff0c;已经成为企业级智能聊天平台的核心挑战之一。尤其是像 LobeChat 这类承载着用户长期会话、文件交互和多模型调用的 AI 助手门户&#xff0c;任何一次发…

作者头像 李华
网站建设 2026/4/16 9:08:02

2025年主流代码托管平台横向评测:本土化与全球化之争

2025年主流代码托管平台横向评测&#xff1a;本土化与全球化之争 在数字化转型加速的2025年&#xff0c;代码托管平台已成为开发者日常工作中不可或缺的基础设施。随着全球开发协作模式日益普及&#xff0c;如何选择适合团队需求的代码托管平台成为技术决策者的重要课题。本文将…

作者头像 李华