用 Jquery 的UI DRAG组件实现拖动功能


'最近要实现一下facebook中的photo tag功能,并对其进行扩展,在实现拖动功能时采用了$.event.special.drag 发现在实现被拖动的层不能超出固定的大小很是麻烦,不过实现了,趁放假考虑一下其它的方法,发现mootools框架中的拖动可以很容易的实现,不太相信jquery实现了,只是怀疑自己没有找到而已,后来想到了UI组件,在进行一番的文档查看后发现了ui.droppable.js这个文件。

经过研究写了一个小的DEMO,哈。假期后准备再改造一下
  1. <!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.0Transitional//EN">
  2. <HTML>
  3. <HEAD>
  4. <TITLE>NewDocument</TITLE>
  5. <METANAME="Generator"CONTENT="EditPlus">
  6. <METANAME="Author"CONTENT="">
  7. <METANAME="Keywords"CONTENT="">
  8. <METANAME="Description"CONTENT="">
  9. <scriptsrc="./jquery-1.2.6.js"></script>
  10. <scriptsrc="./ui/ui.core.js"></script>
  11. <scriptsrc="./ui/ui.draggable.js"></script>
  12. <SCRIPTLANGUAGE="JavaScript">
  13. <!--
  14. $(function(){
  15. $('#inter').draggable({
  16. containment:$('#outer')
  17. });
  18. });
  19. //-->
  20. </SCRIPT>
  21. </HEAD>
  22. <BODY>
  23. <divid='outer'style="width:500px;height:500px;background:#EEE">
  24. <divid='inter'style="width:100px;height:100px;background:#ccc"></div>
  25. </div>
  26. </BODY>
  27. </HTML>
其中 containment后面对应的是一个DOM对像,如果直接用
containment: 'outer'这样是行不通的,开始没有在意直接写成了 containment:'outer'结果无效果,最后试试
containment:$('#outer') 可行、看来不系统的学习还是要走不少弯路的


不过最终还是有些问题,
如果在outer外面再加一个层
  1. <divstyle="width:500px;height:200px;"></div>
这样还是有问题,看来还是要计算一下outer层的top,left这个坐标值

应该和 droppable options 中的axis有关系统,明天再研究一下看看

  1. axis:'100,100'

你可能感兴趣的:(JavaScript,jquery,UI,Facebook,mootools)