鼠标拖动DIV边框改变大小问题

怎么设置成只有右边的边框才能拖动,改变大小。在网上找的一段代码,只要点击DIV都可以改变大小。而且,我用 cursor: e-resize; 属性,鼠标移到DIV上,就变成了左右可拖动的箭头形状。

问题: 我现在想做的就是,鼠标移上去,只有鼠标移到右边的边框时,鼠标形状才变成左右可拖动的箭头形状。并且只有拖动右边的边框时才能改变div宽度。

$(function () {
  //绑定需要拖拽改变大小的元素对象   
  bindResize(document.getElementById('test'));
});

function bindResize(el) {
  //初始化参数   
  var els = el.style,
    //鼠标的 X 和 Y 轴坐标   
    x = y = 0;
  //邪恶的食指   
  $(el).mousedown(function (e) {
    //按下元素后,计算当前鼠标与对象计算后的坐标  
    x = e.clientX - el.offsetWidth, y = e.clientY - el.offsetHeight;
    //在支持 setCapture 做些东东  
    el.setCapture ? (
      //捕捉焦点   
      el.setCapture(),
      //设置事件   
      el.onmousemove = function (ev) {
        mouseMove(ev || event)
      },
      el.onmouseup = mouseUp
    ) : (
      //绑定事件   
      $(document).bind("mousemove", mouseMove).bind("mouseup", mouseUp)
    )
    //防止默认事件发生   
    e.preventDefault()
  });
  //移动事件   
  function mouseMove(e) {
    //宇宙超级无敌运算中... 
    els.width = e.clientX - x + 'px', //改变宽度
      els.height = e.clientY - y + 'px' //改变高度 
  }
  //停止事件   
  function mouseUp() {
    //在支持 releaseCapture 做些东东   
    el.releaseCapture ? (
      //释放焦点   
      el.releaseCapture(),
      //移除事件   
      el.onmousemove = el.onmouseup = null
    ) : (
      //卸载事件   
      $(document).unbind("mousemove", mouseMove).unbind("mouseup", mouseUp)
    )
  }
}   
阅读 16.9k
1 个回答

1.给元素的mousemove 绑定一个方法 判断鼠标是否移动到右边处于可拖拽范围,
如果是,加上cursor: e-resize;否则cusor:pointer;
2.你上面那段代码 里加上判断 鼠标是否移动到右边。 并且把改变高度的代码删除掉。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏