jQuery实现Div拖动+键盘控制综合效果的方法

本文实例讲述了jQuery实现Div拖动+键盘控制综合效果的方法。分享给大家供大家参考。具体实现方法如下:

代码如下:

<!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="/ajaxjs/jquery1.3.2.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>

希望本文所述对大家的jQuery程序设计有所帮助。

(0)

相关推荐

  • jQuery实现DIV层淡入淡出拖动特效的方法

    本文实例讲述了jQuery实现DIV层淡入淡出拖动特效的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <html> <head> <title>jQuery实现DIV层淡入淡出的拖动效果)</title> <style type="text/css"> #div2 {     position:absolute;     width:400px;     height:300px;     border

  • jquery实现仿JqueryUi可拖动的DIV实例

    本文实例讲述了jquery实现仿JqueryUi可拖动的DIV.分享给大家供大家参考.具体如下: 这是用Jquery写的代码,仿JQUERYUI的Draggable或者是Dialog,希望大家喜欢,写的一个小东西.参考了下网上的其他人写的类似代码,但是不完全模仿 <html> <head> <meta charset="utf-8" /> <style type="text/css"> #typewords { } #

  • jQuery拖动div、移动div、弹出层实现原理及示例

    代码演示: http://www.imqing.com/demo/movediv.html 大概原理: 使div的position为绝对定位absolute,然后控制其top与left值,需要监听鼠标事件,主要用到mousedown, mousemove, mouseup. 在mousedown后,记录mousedown时鼠标与需要移动的div的位置,然后取得两者之差,得到在鼠标移动后,div的位置.即: left = 当前鼠标位置.x - (鼠标点击时的.x值 - div的初始位置x值) to

  • jQuery 可以拖动的div实现代码 脚本之家修正版

    当然,代码使用起来也非常的方便,很多东西就不用自己再去琢磨了. 研究的过程中顺便用jQuery实现了一个div的拖动,代码附于本文结尾. 实现的思路请参考我的可以拖动的DIV(二)一文. 在参考jQuery中文网站中的例子时,我发现他们在div窗口标题栏触发click事件时,将div的位置移上了一些,而mouseup的事件注册在整个div窗口上,这个思路让我很受启发,解决了鼠标移动很快而div不能跟上导致的错误,非常好的解决办法. 另外,请注意事件起泡,在jQuery以及任何实现div拖动的js

  • jquery实现可拖动DIV自定义保存到数据的实例

    看到一个不错的jquery插件,可拖动DIV,顺序可保存到数据库的一个实例:这里就以其中PHP实例简单说明一下: 复制代码 代码如下: <?php  //post到后台的数据      if ($_POST) {          $ids = $_POST["ids"];          for ($idx = 0; $idx < count($ids); $idx+=1) {              $id = $ids[$idx];              $o

  • jquery div拖动效果示例代码

    复制代码 代码如下: <%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-

  • jQuery实现单击弹出Div层窗口效果(可关闭可拖动)

    本文实例讲述了jQuery实现单击弹出Div层窗口效果.分享给大家供大家参考.具体如下: 这是一款jquery实现的可拖动可关闭的弹出框效果,网上已经有很多类似效果了,网页上实现这种效果其实并不难,现在又有了jquery让我们用,更方便了,本代码演示了在CSS代码.JavaScript代码和HTML三者结合的情况下,如何实现一个可关闭的弹出窗口,鼠标点击关闭按钮后将其关闭,然后会显示打开按钮,单击这个按钮即弹出这个层窗口. 运行效果截图如下: 在线演示地址如下: http://demo.jb51

  • jQuery实现简单的DIV拖动效果

    本文实例讲述了jQuery实现简单的DIV拖动效果.分享给大家供大家参考,具体如下: 创建一个HTML文件,复制以下代码进去,修改jquery文件(没有的到网上去下一个,我使用的是jquery-1.8.2),即可以运行了 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&

  • 利用JQuery+EasyDrag 实现弹出可拖动的Div,同时向Div传值,然后返回Div选中的值

    原来我们要写一个客户端的特效,要写一两天的JavaScript,然后再调试一两天,才可以看见端倪.现在我们只要使用JQuery和他的 plugin,就可以任意的实现我们脑海中的特效,感谢他们的编写者对人类的贡献(一百个西红柿砸过来..............). 我今天实现的需求是一个需要从列表页面中选择要导出到word中的列,然后在将选中列的内容导出到word中,同时为了增加通用性,列的个数不是固定的,也就是说这张表格可能是4列,也可能是5列,待选择的列数目不固定.例如:有下面的一张表格,然后

  • jQuery实现div随意拖动的实例代码(通用代码)

    注意js放的位置,要放的靠近,若被其他覆盖,则无法移动. 比如: <div id="move">可移动的DIV</div> 引入jquery.js, jquery-ui.js, <script scr="http://code.jquery.com/jquery-1.10.2.js"></script> <script scr="http://code.jquery.com/ui/1.11.4/jque

随机推荐