当前位置: 首页 > news >正文

jQuery UI 实例 - 定位(Position)

jQuery UI Position(定位)实例

Position是 jQuery UI 中非常实用的工具方法,用于将一个元素精确地定位到另一个元素(或页面、窗口)的相对位置。它支持碰撞检测(collision)、偏移(offset)、自动调整等功能,常用于实现工具提示(Tooltip)、下拉菜单、上下文菜单、对话框居中、气泡提示、拖拽吸附等场景。

官方文档:https://jqueryui.com/position/

下面提供几个渐进实例,从基础到高级,代码使用最新 CDN,可直接复制到 HTML 文件测试。

1.基础定位(相对目标元素)

将一个元素定位到另一个元素的指定位置。

<!DOCTYPEhtml><html><head><metacharset="utf-8"><title>jQuery UI Position 基础示例</title><linkrel="stylesheet"href="//code.jquery.com/ui/1.13.2/themes/smoothness/jquery-ui.css"><scriptsrc="//code.jquery.com/jquery-3.6.0.min.js"></script><scriptsrc="//code.jquery.com/ui/1.13.2/jquery-ui.min.js"></script><style>#target{width:150px;height:100px;background:#3498db;margin:100px auto;position:relative;}#positioned{width:100px;height:80px;background:#e74c3c;color:white;padding:10px;position:absolute;}</style></head><body><buttonid="pos1">右下角</button><buttonid="pos2">左上角</button><buttonid="pos3">居中</button><divid="target">目标元素</div><divid="positioned">被定位元素</div><script>$(function(){$("#pos1").click(function(){$("#positioned").position({my:"left top",// 被定位元素的参考点at:"right bottom",// 目标元素的参考点of:"#target"// 目标元素});});$("#pos2").click(function(){$("#positioned").position({my:"right bottom",at:"left top",of:"#target"});});$("#pos3").click(function(){$("#positioned").position({my:"center center",at:"center center",of:"#target"});});});</script></body></html>
2.常用选项(offset、collision)
<buttonid="tooltipBtn">悬停查看提示</button><divid="tooltip"style="display:none;background:#333;color:white;padding:10px;border-radius:6px;position:absolute;">这是一个工具提示框,支持自动翻转!</div><script>$("#tooltipBtn").hover(function(){$("#tooltip").show().position({my:"left+10 center",at:"right center",of:this,collision:"flipfit"// 先翻转,再适应视口});},function(){$("#tooltip").hide();});</script>
3.定位到鼠标或窗口

常用于自定义上下文菜单或气泡。

<divid="contextMenu"style="display:none;background:#fff;border:1px solid #ccc;padding:10px;box-shadow:0 4px 10pxrgba(0,0,0,0.2);position:absolute;"><ul><li>复制</li><li>粘贴</li><li>删除</li></ul></div><script>$(document).on("contextmenu",function(e){// 右键$("#contextMenu").show().position({my:"left top",at:"left top",of:e,// 定位到鼠标事件offset:"10 10"});e.preventDefault();// 阻止默认右键菜单});$(document).click(function(){$("#contextMenu").hide();});</script>
4.窗口居中 + 动态调整
<buttonid="centerWindow">窗口居中</button><script>$("#centerWindow").click(function(){$("#positioned").position({my:"center center",at:"center center",of:window,// 定位到窗口collision:"none"// 不处理碰撞});});// 窗口大小变化时重新定位$(window).resize(function(){$("#positioned").position({my:"center center",at:"center center",of:window});});</script>

常用 my/at 值组合

小技巧

Position 是实现高级交互布局的核心工具,常用于自定义下拉菜单、气泡提示、浮动工具栏。如果你需要完整自定义 Tooltip下拉菜单、或拖拽时吸附定位的示例,请告诉我!

http://www.cnnetsun.cn/news/166288.html

相关文章:

  • 自走式除草机器人结构设计
  • Open-AutoGLM体温监测实战指南(从部署到数据分析全流程曝光)
  • Open-AutoGLM如何实现个性化体重预测:3个你必须掌握的技术细节
  • 【家庭自动化终极方案】:用Open-AutoGLM实现零遗忘家务安排
  • GraphRAG实战终极指南!从0到1打通OpenAI+LangChain+Neo4j,收藏这篇就够了!
  • 最近在研究石墨烯材料,这玩意儿真是神奇。说它是“材料界的明星”一点也不夸张。石墨烯的导电性和导热性都超强,而且它只有一层碳原子厚,简直是纳米技术的完美代表
  • Open-AutoGLM如何重构洗衣流程:9大优化策略全公开
  • 【AI营养师来了】:Open-AutoGLM饮食热量统计系统深度测评与优化建议
  • 基于单片机的智能门禁系统的设计与实现
  • 基于PLC工业机器人视觉定位及自动码垛系统的设计
  • 基于SSM的大王门店管理系统设计与实现
  • 网络安全完全指南:从小白到高手的系统学习路线与实战精讲
  • C++ 最強武器:利用類型系統實現零成本抽象
  • (28)全注解开发底层原理
  • jQuery UI 实例 - 对话框(Dialog)
  • 模型版本迭代中的回归测试策略
  • 【Open-AutoGLM家务提醒安排】:揭秘智能家庭任务调度背后的AI黑科技
  • Open-AutoGLM食材购买避坑指南:90%人忽略的3类关键营养匹配原则
  • Open-AutoGLM任务中断恢复实战(断点续训技术大揭秘)
  • 【Open-AutoGLM饮食热量统计】:揭秘AI自动识别食物热量的黑科技与实测效果
  • Linly-Talker如何避免‘恐怖谷效应’?外观设计心理学研究
  • 基于Spring Boot的儿童福利院管理系统的设计与实现毕业设计
  • 基于Android的网上点餐APP
  • 如何用Open-AutoGLM实现秒级故障响应?一线架构师亲授压箱底方案
  • Open-AutoGLM日志系统揭秘,掌握这6个参数才算真正入门
  • jQuery UI 实例 - 放置(Droppable)
  • 探索三相两电平光伏逆变器DC - AC部分的Simulink仿真之旅
  • 【AI推理服务稳定性提升】:基于Open-AutoGLM的后台运行配置最佳实践
  • Open-AutoGLM网络配置避坑指南(一线专家亲授12年实战经验)
  • Open-AutoGLM报错代码怎么破:从日志到修复的7步闭环流程