• 用javascript进行拖拽3(转)


    运行代码框

    [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

    你会注意到这个代码几乎是前面的全集,将前面的合在一起就实现了拖拽效果了.

    当我们点击一个item时,我们就获取了很多变量,如鼠标位置,鼠标位置自然就包含了那个item的坐标信息了.如果我们点击了一个20*20px图像的正中间,那么鼠标的相对坐标为{x:10,y:10}.当我们点击这个图像的左上角那么鼠标的相对坐标为{x:0,y:0}.当我们点击时,我们用这个方法取得一些鼠标与图片校对的信息.如果我们不能加载页面item,那么信息将是document信息,会忽略了点击的item信息.

    mouseOffset函数使用了另一个函数getPosition.getPosition的作用是返回item相对页面左上角的坐标,如果我们尝试获取item.offsetLeft或者item.style.left,那么我们将取得item相对与父级的位置,不是整个document.所有的脚本我们都是相对整个document,这样会更好一些.

    为了完成getPosition任务,必须循环取得item的父级,我们将加载内容到item的左/上的位置.我们需要管理想要的top与left列表.

    自从定义了mousemove这个函数,mouseMove就会一直运行.第一我们确定item的style.position为absolute,第二我们移动item到前面定义好的位置.当mouse点击被释放,dragObject被设置为null,mouseMove将不在做任何事.

    Dropping an Item

    前面的例子目的很简单,就是拖拽item到我们希望到的地方.我们经常还有其他目的如删除item,比如我们可以将item拖到垃圾桶里,或者其他页面定义的位置.

    很不幸,我们有一个很大的难题,当我们拖拽,item会在鼠标之下,比如mouseove,mousedown,mouseup或者其他mouse action.如果我们拖拽一个item到垃圾桶上,鼠标信息还在item上,不在垃圾桶上.

    怎么解决这个问题呢?有几个方法可以来解决.第一,这是以前比较推荐的,我们在移动鼠标时item会跟随鼠标,并占用了mouseover/mousemove等鼠标事件,我们不这样做,只是让item跟随着鼠标,并不占用mouseover等鼠标事件,这样会解决问题,但是这样并不好看,我们还是希望item能直接跟在mouse下.

    另一个选择是不做item的拖拽.你可以改变鼠标指针来显示需要拖拽的item,然后放在鼠标释放的位置.这个解决方案,也是因为美学原因不予接受.

    最后的解决方案是,我们并不去除拖拽效果.这种方法比前两种繁杂许多,我们需要定义我们需要释放目标的列表,当鼠标释放时,手工去检查释放的位置是否是在目标列表位置上,如果在,说明是释放在目标位置上了.

    /*
    All code from the previous example is needed with the exception
    of the mouseUp function which is replaced below
    */

    var dropTargets = [];

    function addDropTarget(dropTarget){
     dropTargets.push(dropTarget);
    }

    function mouseUp(ev){
     ev           = ev || window.event;
     var mousePos = mouseCoords(ev);

     for(var i=0; i<dropTargets.length; i++){
      var curTarget  = dropTargets[i];
      var targPos    = getPosition(curTarget);
      var targWidth  = parseInt(curTarget.offsetWidth);
      var targHeight = parseInt(curTarget.offsetHeight);

      if(
       (mousePos.x > targPos.x)                &&

       (mousePos.x < (targPos.x + targWidth))  &&
       (mousePos.y > targPos.y)                &&
       (mousePos.y < (targPos.y + targHeight))){
        // dragObject was dropped onto curTarget!
      }
     }

     dragObject   = null;
    }

  • 相关阅读:
    IT经典书籍——Head First系列【推荐】
    IT经典书籍——Head First系列【推荐】
    使用JSP实现用户登录
    使用JSP实现用户登录
    【知乎精选】如何面试一个产品经理?如何判断一个产品经理是否是一个很牛的产品经理?
    淘宝API总结
    「用户标签」在数据库设计时应该如何存储?
    【爬虫集合】抖音API分析
    商业架构体系
    短视频带货
  • 原文地址:https://www.cnblogs.com/cuihongyu3503319/p/650514.html
Copyright © 2020-2023  润新知