Javascript 简单实现鼠标拖动DIV

http://zhangbo-peipei-163-com.iteye.com/blog/1740078

比较精简的Javascript拖动效果函数代码

http://www.jb51.net/article/10578.htm

<html>
<head><title>拖动效果函数演示 by Longbill.cn</title>
<style>
body
{
    font-size:12px;
    color:#333333;
    border : 0px solid blue;
}
div
{
    position : absolute;
    background-color : #c3d9ff;
    margin : 0px;
    padding : 5px;
    border : 0px;
    width : 100px;
    height:100px;
}
</style>
</head>
<body>
<script>
function drag(o,s)
{
    if (typeof o == "string") o = document.getElementById(o);
    o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
    o.orig_y = parseInt(o.style.top) - document.body.scrollTop;
    o.orig_index = o.style.zIndex;  

    o.onmousedown = function(a)
    {
        this.style.cursor = "move";
        this.style.zIndex = 10000;
        var d=document;
        if(!a)a=window.event;
        var x = a.clientX+d.body.scrollLeft-o.offsetLeft;
        var y = a.clientY+d.body.scrollTop-o.offsetTop;
        //author: www.longbill.cn
        d.ondragstart = "return false;"
        d.onselectstart = "return false;"
        d.onselect = "document.selection.empty();"  

        if(o.setCapture)
            o.setCapture();
        else if(window.captureEvents)
            window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);  

        d.onmousemove = function(a)
        {
            if(!a)a=window.event;
            o.style.left = a.clientX+document.body.scrollLeft-x;
            o.style.top = a.clientY+document.body.scrollTop-y;
            o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
            o.orig_y = parseInt(o.style.top) - document.body.scrollTop;
        }  

        d.onmouseup = function()
        {
            if(o.releaseCapture)
                o.releaseCapture();
            else if(window.captureEvents)
                window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
            d.onmousemove = null;
            d.onmouseup = null;
            d.ondragstart = null;
            d.onselectstart = null;
            d.onselect = null;
            o.style.cursor = "normal";
            o.style.zIndex = o.orig_index;
        }
    }  

    if (s)
    {
        var orig_scroll = window.onscroll?window.onscroll:function (){};
        window.onscroll = function ()
        {
            orig_scroll();
            o.style.left = o.orig_x + document.body.scrollLeft;
            o.style.top = o.orig_y + document.body.scrollTop;
        }
    }
}
</script>  

<div id="div1" style="left:10px;top:10px;">div1:我可以被拖动</div>
<div id="div2" style="left:120px;top:10px;background-color : #f3d9ff">div2:来拖我呀</div>
<div id="div3" style="left:230px;top:10px;background-color : #c3ffff">div3:我随便你拖</div>
<div id="div4" style="left:10px;top:120px;background-color : #c3d944">div4:我可以随窗口滑动,把我拖到最下面,然后滚动网页看看</div>
<div id="div5" style="left:120px;top:120px;background-color : #f3d944">作者: Longbill
<a href=http://www.longbill.cn target=_blank>www.longbill.cn</a>
</div>
<div id="div6" style="left:230px;top:120px;background-color : #e3f944;width:200px;">参数说明:

drag(obj [,scroll]);

obj:对象的id或对象本身;

scroll(可选):对象是否随窗口拖动而滑动,默认为否

鼠标右键查看源代码
</div>  

<script>
drag("div1");
drag("div2");
drag("div3");
drag("div4",1);
drag("div5",1);
drag("div6",1);  

</script>  

</body>

  

avascript 简单实现鼠标拖动DIV

博客分类:

javascript拖动DIV

Javascript简单的实现鼠标拖动DIV的效果。没有什么技术含量,全当笔记。 
要想实现鼠标拖动效果,免不了要计算元素在浏览器中的坐标,那首先来学习一下各种坐标。 
参考: 
Javascript获取页面的各种坐标汇总

实现拖动: 
1.定义需要的变量

Javascript代码  

  1. var bool=false,
  2. pageX=0,
  3. pageY=0,
  4. //需要拖动的目标DIV
  5. element = $("#tb_window"),
  6. eWidth = element.width(),
  7. eHeight = element.height(),
  8. //在该DIV的范围内拖动
  9. pElement = $("#flashFrame"),
  10. pWidth = pElement.width(),
  11. pHeight = pElement.height();

2.鼠标mousedown事件计算鼠标焦点x相对目标DIV的坐标

Javascript代码  

  1. element.mousedown(function(event)
  2. {
  3. needMove=true;
  4. var position = element.position();
  5. pageX = event.pageX-position.left; //鼠标和DIV的相对坐标
  6. pageY = event.pageY-position.top;
  7. element.css(‘cursor‘,‘move‘);
  8. });

3.鼠标mouseup事件将变量needMove赋值false,表示不需要移动DIV

Javascript代码  

  1. element.mouseup(function(event)
  2. {
  3. needMove=false;
  4. });

4.鼠标的mousemove事件开始移动目标DIV

Javascript代码  

  1. element.mousemove(function(event)
  2. {
  3. if(!needMove) {return;}
  4. //鼠标在页面的坐标 - 鼠标和DIV的相对坐标 = DIV在页面的坐标
  5. var ePageX = event.pageX;
  6. var ePageY = event.pageY;
  7. var x = ePageX-pageX;
  8. var y = ePageY-pageY;
  9. if (ePageX <= eWidth/ 2 || ePageX >= pWidth - eWidth / 2)
  10. {
  11. return;
  12. }
  13. if (ePageY< eHeight / 2 || ePageY >= pHeight - eHeight / 2)
  14. {
  15. return;
  16. }
  17. element.css("left", x);
  18. element.css("top", y);
  19. });

5.总结,以上代码只是简单实现鼠标拖动DIV的思路(当然功能也是可以的),具体的性能,兼容性和代码扩展性都有待商榷。比如:还可以增加参数控制DIV在指定的大小范围内拖动等。

时间: 2024-10-06 17:14:24

Javascript 简单实现鼠标拖动DIV的相关文章

简单的鼠标拖动效果

使用js实现简单的鼠标拖动效果,但此部分代码有个小小的BUG,后期改进好我会写进来,但基本的效果已经实现,请大家参考. <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>鼠标移动</title> <style> #box{ width: 50px; height: 50px; position:

javascript如何实现随意拖动的层

javascript如何实现随意拖动的层: 在很多应用中都有拖动层移动的效果的扩展,下面就通过实例简单介绍一下如何利用javascript实现随意拖动一个层的效果. 代码实例如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="author" content="http://www.51texiao.cn/"

简单的鼠标可拖动div 兼容IE/FF

来源:http://www.cnblogs.com/imwtr/p/4355416.html 作者: 主要思路: 一个div,注册监听onmousedown事件,然后处理获取的对象及其相关值(对象高度,clientX/clientY位置等) 并继而转为监测onmousemove事件,在鼠标移动事件中更新div对象的位置属性 鼠标松开的时候解除监听,更新位置完成. 需要注意的两点: 1.更新对象的位置需要用到o.style.left等,这些CSS属性只能内嵌才能被访问到: <div id="

鼠标拖动改变DIV等网页元素的大小的最佳实践

1.初次实现 1.1 html代码 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>div change

javascript中区分鼠标单击和拖动事件

在javascript中,一般的DOM元素如div,都有onmousedown.onmousemove.onmouseup这3个鼠标事件. <div id="div1" onmousedown="down();" onmouseup="up();" onmousemove="move();"></div> 当鼠标在div1上移动或者按下左键拖动的时候,都会触发onmousemove事件.如何区分这2种事

拖动鼠标改变div层的大小宽度

<html> <head> <title>拖动鼠标改变div层的大小宽度-石家庄色彩顾问-亿诚</title> <meta content="text/html; charset=gb2312" http-equiv="Content-Type"> <style> { box-sizing: border-box; moz-box-sizing: border-box } #testDiv {

JavaScript总结之鼠标划过弹出div单击出现对话框

为了满足他们的永无止境的要求,我可谓是任劳任怨啊,累断了双手,看瞎了双眼.这个是来写鼠标划过一个按钮,然后弹出一个小提示框解释,另外根据radio是否选中,判断点击后如何执行,然后执行之后再有一个确认或取消.其实部分想要的功能可以从中截取. js代码: 1 <script type="text/javascript"> 2 function sAlert_jobdel(str){ 3 var msgw,msgh,bordercolor; 4 msgw=400;//提示窗口的

jQuery实现鼠标拖动改变Div高度

最近项目中需要在DashBoard页面做一个事件通知栏,该通知栏固定位于页面底部,鼠标拖动该DIV实现自动改变高度扩展内容显示区域. 以下是一个设计原型,基于jQuery实现,只实现了拖动效果,没有做页面美化,可以根据需求做相应修改. 直接上代码 1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd&quo

javascript拖动div

div拖动代码,在用此代码之前,你可能需要将你需要拖动的元素style设置position: absolute; #textareaSavaDiv{ position: absolute; right:50px; width:300px; height:300px; } html <div id="textareaSavaDiv"> <input type="text" id="username"/> </div&g