方法如下:

  1. var params = {
    left: 0,
  2. top: 0,
  3. currentX: 0,
  4. currentY: 0,
  5. flag: false
  6. };
  7. var getCss = function(o,key){
  8. return o.currentStyle? o.currentStyle[key] : document.defaultView.getComputedStyle(o,false)[key];
  9. };
  10. var startDrag = function(bar, target, callback){
  11. if(getCss(target, "left") !== "auto"){
  12. params.left = getCss(target, "left");
  13. }
  14. if(getCss(target, "top") !== "auto"){
  15. params.top = getCss(target, "top");
  16. }
  17. bar.onmousedown = function(event){
  18. params.flag = true;
  19. if(!event){
  20. event = window.event;
  21. bar.onselectstart = function(){
  22. return false;
  23. }
  24. }
  25. var e = event;
  26. params.currentX = e.clientX;
  27. params.currentY = e.clientY;
  28. };
  29. document.onmouseup = function(){
  30. params.flag = false;
  31. if(getCss(target, "left") !== "auto"){
  32. params.left = getCss(target, "left");
  33. }
  34. if(getCss(target, "top") !== "auto"){
  35. params.top = getCss(target, "top");
  36. }
  37. };
  38. document.onmousemove = function(event){
  39. var e = event ? event: window.event;
  40. if(params.flag){
  41. var nowX = e.clientX, nowY = e.clientY;
  42. var disX = nowX - params.currentX, disY = nowY - params.currentY;
  43. target.style.left = parseInt(params.left) + disX + "px";
  44. target.style.top = parseInt(params.top) + disY + "px";
  45. if (event.preventDefault) {
  46. event.preventDefault();
  47. }
  48. return false;
  49. }
  50. if (typeof callback == "function") {
  51. callback(parseInt(params.left) + disX, parseInt(params.top) + disY);
  52. }
  53. }
  54. };
 使用方法为
     startDrag("触发拖拽的对象","被拖拽的对象")

js实现简单拖拽效果的更多相关文章

  1. js插件-简单拖拽

    前端开发的时候,有好多地方用到拖拽效果,当然 http://jqueryui.com/draggable/  是个不错的选择,but 我是个打破砂锅问到底的人,抽点时间用js小小的实现了类似的插件,话 ...

  2. 用JS实现版面拖拽效果

    类似于这样的一个版面,点击标题栏,实现拖拽效果. 添加onmousedown事件 通过获取鼠标的坐标(clientX,clientY)来改变面板的位置 注意:面板使用绝对定位方式,是以左上角为参考点, ...

  3. Javascript:简单拖拽效果的实现

    核心代码: /* *完成一个拖拽事件由三大事件组成: *1:onmousedown:选择元素 *2:onmousemove:移动元素 *3:onmouseup:释放元素 */ function dra ...

  4. 好玩的原生js的简单拖拽

    这个拖拽的图片不是唯一的,拿到代码自己添加一张照片就可以啦 <!DOCTYPE html><html> <head> <meta charset=" ...

  5. 拖拽系列一、JavaScript实现简单的拖拽效果

        前端拖拽相关应用汇总 在现实生活中就像男孩子牵着(拖着)女朋友的手穿过马路:从马路的一端走到另一端这种场景很常见: 而在前端开发中拖拽效果也算是前端开发中应用最常见.最普遍的特效:其拖拽涉及知 ...

  6. 原生js简单实现拖拽效果

    实现弹窗拖拽效果的原理是:按下鼠标并移动——拖拽移动物体,抬起鼠标——停止移动.主要触发三个事件:onmousedown.onmousemove以及onmouseup: 首先搭建结构:一个宽350px ...

  7. React.js实现原生js拖拽效果及思考

    一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...

  8. JavaScript实现最简单的拖拽效果

    一.一些无关痛痒的唠叨 拖拽还是挺不错的一个页面效果,我个人认为,其生命力在于可以让用户自己做一些操作,所谓自定义.例如: ①浏览器标签顺序的拖拽切换 现在基本上所有的选项卡式的浏览器都有顺序拖拽切换 ...

  9. js拖拽效果

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. jsp grid can not be used in this ('quirks') mode

    设置: <!--设置IE文档模式  --> <meta http-equiv="X-UA-Compatible" content="IE=9" ...

  2. Jquery 属性选择器&设置元素属性

    什么是属性选择器呢?感觉理解起来有点难,举个例子就很容易明白了,<div id="ajaxa"></div>这里的id就是属性,这下就很容易理解了, jqu ...

  3. c++Builder debug DataSet Visualizer

    c++Builder debug DataSet Visualizer delphi 正常,c++builder报错. fdMemTable->SaveToFile("d:\\DSdb ...

  4. synchronized 和 lock 的区别

    1.Lock不是Java语言内置的,synchronized是Java语言的关键字,因此是内置特性.Lock是一个类,通过这个类可以实现同步访问: 2.Lock和synchronized有一点非常大的 ...

  5. linux配置sphinx

    1. 配置索引 cd /usr/local/sphinx/etc/ cp sphinx.conf.dist sphinx.conf //备份配置文件,防止改错 vim sphinx.conf 配置文件 ...

  6. 列表(list) 的 基本操作

    举例说明:names = ["zhangyang", "guyun", 'xiangpeng', ['alex','jack'], "xuliangc ...

  7. 重置mysql5.7密码

    其实想要重置 5.7 的密码很简单,就一层窗户纸: 1.修改 /etc/my.cnf,在 [mysqld] 小节下添加一行:skip-grant-tables=1 这一行配置让 mysqld 启动时不 ...

  8. SpringBoot读取application.properties文件内容

    application.properties存储数据的方式是key-value. application.properties内容 userManager.userFile=data/user.pro ...

  9. ORM一对多查询对象

    正向查询: 取人民日报出版社出版的所有书籍 方式一: pub_obj = Publish.objects.filter(name='人民日报')[0] ret = Book.objects.filte ...

  10. category,extension区别

    extension是在编译的时候就决定了的,跟普通的头文件是一样的,所以可以添加属性.实例变量.方法.并且添加extension的前提是你有这个类的源代码. category是在程序运行的时候才决定的 ...