返回顶部

收藏

jQuery Div拖动+键盘控制综合效果

更多

请使用“试试效果”看效果呀!

[JavaScript]代码

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jQuery Div拖动+键盘控制综合效果</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<script src="http://outofmemory.cn/static/js/jquery-1.7.2.min.js"></script>
</head>
<body>
预览时看不到效果,刷新一下即可
<div id="text" style="width:120px;height:60px;background:#F06;position:absolute;left:500px;top:90px;cursor:move;"></div>
<script type="text/javascript">
var msgObj = document.getElementById('text');
var posx = 0;
var posy = 0;
var moveable = false;
var MouseDownEvent = document.onmousedown;
var MouseMoveEvent = document.onmousemove;
var MouseUpEvent = document.onmouseup;
msgObj.onmousedown = function(evt) {
    var evt = evt||window.event;
    moveable = true; 
    posy = evt.clientY-parseInt(msgObj.style.top);
    posx = evt.clientX-parseInt(msgObj.style.left);
    document.onmousemove = function(evt) {
        if (moveable) {
            var evt = evt||window.event;
            msgObj.style.left = evt.clientX - posx + "px";
            msgObj.style.top = evt.clientY - posy + "px";
        }
        change();
    };
    document.onmouseup = function () { 
        if (moveable) { 
            document.onmousemove = MouseMoveEvent;
            document.onmouseup = MouseUpEvent;
            moveable = false; 
            posx = 0;
            posy = 0;
        } 
    };
}
var v=1;
var a=0.9;
var h=document.documentElement.clientHeight;
function scroll(){
    var timer=setInterval(function(){
        v +=a;
        var top=(parseInt(msgObj.style.top)||0);
        if(top+v>h-70){
            if(v<2)clearInterval(timer);
            msgObj.style.top=h-70+"px";
            v=-v*0.5;   
        }else{
            msgObj.style.top=top+v+"px";
        }
        change();
    },10);
};
$(document).keyup(function(e){
    var e = e || window.event ;
    if(e.which == 13){
        scroll();   
    }
})
var x = 4 ;
var y = 4 ;
function newpro(){
    var Height = document.documentElement.clientHeight ;
    var Width = document.documentElement.clientWidth ;
    var newobj = document.createElement('div');
    newobj.setAttribute('id','bigbox');
    newobj.style.position = 'absolute';
    newobj.style.left = 20 +"px";
    newobj.style.top = 80 +"px";
    newobj.style.height = Height/x +"px" ;
    newobj.style.width = Width/y +"px" ;
    newobj.style.borderWidth = 1+"px";
    newobj.style.borderColor = "#ff6500";
    newobj.style.borderStyle = 'solid' ;
    newobj.innerHTML='<div id="minbox"></div>';
    document.body.appendChild(newobj);
    change();
}
function change(){
    var minobj = document.getElementById('minbox');
    minobj.style.position = 'absolute';
    minobj.style.left = parseInt(msgObj.style.left)/x +"px";
    minobj.style.top = parseInt(msgObj.style.top)/y +"px";
    minobj.style.height = 20 +"px" ;
    minobj.style.width = 30 +"px" ;
    minobj.style.background = "#F06";
}
window.onload = function(){
    newpro();
}
</script>
</body>
</html>

标签:javascript,jquery

收藏

0人收藏

支持

0

反对

0

相关聚客文章
  1. 张映 发表 2014-03-05 08:20:07 angularjs 设置全局变量的3种方法
  2. 和大头 发表 2011-09-18 08:25:19 ProcessingJS介绍
  3. wangshuai 发表 2014-02-20 06:46:09 jquery交换两个元素的位置
  4. ajaxj 发表 2014-07-25 01:05:11 javascript 删除节点
  5. David Walsh 发表 2014-09-24 16:25:07 iOS Mobile Safari Hover Menu Fix
  6. 新一 发表 2015-02-02 13:56:18 解决ajax jQuery $.post() 不执行回调函数
  7. 逝去日子 发表 2015-04-15 13:25:49 MVC实现DropdownList联动
  8. kvkens 发表 2015-03-02 06:44:00 Layer For Mobile、PC
  9. cc 发表 2013-04-26 02:02:33 jquery与discuz原型protype冲突解决方法
  10. 周亮 发表 2012-07-08 09:30:17 JavaScript中的this
  11. 四火 发表 2013-04-21 12:36:05 你没有抓住Promises的要点
  12. shandawang 发表 2015-06-11 09:24:13 jquery插件

发表评论