• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
00fairy00の学习园地
博客园    首页    新随笔    联系   管理    订阅  订阅
NO.29 【转载】拖放层效果
代码
<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> 

 

posted on 2010-01-20 11:29  00fairy00  阅读(252)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3