news 2026/5/13 9:58:36

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/5/10 17:35:16

jQuery EasyUI 菜单与按钮 - 创建链接按钮(Link Button)

jQuery EasyUI 菜单与按钮 - 创建链接按钮&#xff08;Link Button&#xff09; jQuery EasyUI 的 linkbutton 组件是一个美化的超链接按钮&#xff08;基于 <a> 标签&#xff09;&#xff0c;支持图标、文本、不同大小、纯图标模式、启用/禁用状态、切换&#xff08;to…

作者头像 李华
网站建设 2026/5/10 16:53:20

23、解锁量子优势:供应链优化的实用应用与案例研究

解锁量子优势:供应链优化的实用应用与案例研究 1. 供应链优化中的量子计算简介 随着全球供应链的复杂性不断增加,传统计算方法在处理海量数据和众多优化挑战时显得力不从心。量子计算作为一项革命性技术,有望突破经典计算的限制,为供应链优化开辟新的领域。 量子计算利用…

作者头像 李华
网站建设 2026/5/2 9:36:43

2025 CTF 解题思路终极指南:从入门到实战的全题型干货总结

前言&#xff1a;CTF 解题的核心逻辑&#xff08;2025 最新趋势&#xff09; CTF 竞赛已进入 “精细化对抗” 时代&#xff0c;2025 年赛事呈现三大特征&#xff1a;跨模块融合&#xff08;如 Web 密码学&#xff09;、实战化场景&#xff08;云环境 / API 调用&#xff09;、…

作者头像 李华
网站建设 2026/5/11 5:59:49

PC端商城纷纷开通网银支付功能

如今&#xff0c;越来越多的PC端商城纷纷开通网银支付功能&#xff0c;核心原因在于该支付方式能够为用户带来更优质的支付体验。商家只需通过报备白名单API接口&#xff0c;即可实现一次性对接多家银行的服务。当用户在商城完成下单流程并进入支付环节时&#xff0c;系统会跳转…

作者头像 李华
网站建设 2026/5/10 13:39:50

深度剖析GEO优化技术:AI搜索浪潮下的推广创新策略

2025年&#xff0c;用户获取信息的方式正在改变。当企业还在为搜索广告的高成本和传统SEO的漫长周期发愁时&#xff0c;AI搜索平台已悄然成为新的流量入口。GEO优化&#xff08;生成式引擎优化&#xff09;应运而生&#xff0c;它让企业信息在AI回答中被推荐&#xff0c;而不是…

作者头像 李华