用键盘控制DIV && 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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>用键盘控制DIV</title>
<style type="text/css">
html,body{overflow:hidden;}
body{margin:0;padding:0;}
pre{color:green;padding:10px 15px;background:#f0f0f0;border:1px dotted #333;font:12px/1.5 Courier New;margin:12px;}
span{color:#999;}
#box{position:absolute;top:50px;left:300px;width:100px;height:100px;background:red;}
</style>
<script type="text/javascript">
window.onload = function ()
{
    var oBox = document.getElementById("box");
    var bLeft = bTop = bRight = bBottom = bCtrlKey = false;

    setInterval(function ()
    {
        if (bLeft)
        {
            oBox.style.left = oBox.offsetLeft - 10 + "px"
        }
        else if (bRight)
        {
            oBox.style.left = oBox.offsetLeft + 10 + "px"
        }

        if (bTop)
        {
            oBox.style.top = oBox.offsetTop - 10 + "px"
        }
        else if(bBottom)
        {
            oBox.style.top = oBox.offsetTop + 10 + "px"
        }
        //防止溢出
        limit();
    },30);    

    document.onkeydown = function (event)
    {
        var event = event || window.event;
        bCtrlKey = event.ctrlKey;

        switch (event.keyCode)
        {
            case 37:
                bLeft = true;
                break;
            case 38:
                if(bCtrlKey)
                {
                    var oldWidth = oBox.offsetWidth;
                    var oldHeight = oBox.offsetHeight;

                    oBox.style.width = oBox.offsetWidth * 1.5 + "px";
                    oBox.style.height = oBox.offsetHeight * 1.5 + "px";                

                    oBox.style.left = oBox.offsetLeft - (oBox.offsetWidth - oldWidth) / 2 + "px";
                    oBox.style.top = oBox.offsetTop - (oBox.offsetHeight - oldHeight) / 2 + "px";

                    break;
                }
                bTop = true;
                break;
            case 39:
                bRight = true;
                break;
            case 40:
                if(bCtrlKey)
                {
                    var oldWidth = oBox.offsetWidth;
                    var oldHeight = oBox.offsetHeight;

                    oBox.style.width = oBox.offsetWidth * 0.75 + "px";
                    oBox.style.height = oBox.offsetHeight * 0.75 + "px";                

                    oBox.style.left = oBox.offsetLeft - (oBox.offsetWidth - oldWidth) / 2 + "px";
                    oBox.style.top = oBox.offsetTop - (oBox.offsetHeight - oldHeight) / 2 + "px";

                    break;
                }
                bBottom = true;
                break;
            case 49:
                bCtrlKey && (oBox.style.background = "green");
                break;
            case 50:
                bCtrlKey && (oBox.style.background = "yellow");
                break;
            case 51:
                bCtrlKey && (oBox.style.background = "blue");
                break;
        }

        return false
    };

    document.onkeyup = function (event)
    {
        switch ((event || window.event).keyCode)
        {
            case 37:
                bLeft = false;
                break;
            case 38:
                bTop = false;
                break;
            case 39:
                bRight = false;
                break;
            case 40:
                bBottom = false;
                break;
        }
    };

    //防止溢出
    function limit()
    {
        var doc = [document.documentElement.clientWidth, document.documentElement.clientHeight]
        //防止左侧溢出
        oBox.offsetLeft <=0 && (oBox.style.left = 0);
        //防止顶部溢出
        oBox.offsetTop <=0 && (oBox.style.top = 0);
        //防止右侧溢出
        doc[0] - oBox.offsetLeft - oBox.offsetWidth <= 0 && (oBox.style.left = doc[0] - oBox.offsetWidth + "px");
        //防止底部溢出
        doc[1] - oBox.offsetTop - oBox.offsetHeight <= 0 && (oBox.style.top = doc[1] - oBox.offsetHeight + "px")
    }
};
</script>
</head>
<body>
<pre>
红色方块为键盘操作区域,您可以进行如下操作:

上:↑ 下:↓ 左:← 右:→

Ctrl + 1 : 背景变为绿色
Ctrl + 2 : 背景变为黄色
Ctrl + 3 : 背景变为蓝色
Ctrl + ↑ : 放大
Ctrl + ↓ : 缩小
</pre>
<div id="box"></div>
</body>
</html>
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>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Div闪烁</title>
<style type="text/css">
#box{position:absolute;top:50%;left:50%;color:#fff;width:200px;height:200px;background:red;cursor:pointer;letter-spacing:5px;text-align:center;font:12px/200px Arial;margin:-100px 0 0 -100px;}
</style>
<script type="text/javascript">
window.onload = function ()
{
    var oBox = document.getElementById("box");
    var timer = null;        

    oBox.onclick = function ()
    {
        var i = 0;
        clearInterval(timer);
        timer = setInterval(function () {
            oBox.style.display = i++ % 2 ? "none" : "block";
            i > 6 && (clearInterval(timer))
        }, 80)
    }
};
</script>
</head>
<body>
<div id="box">点击我就闪</div>
</body>
</html>
时间: 2024-10-06 00:23:33

用键盘控制DIV && Div闪烁的相关文章

纯js实现用键盘控制DIV上下左右+放大缩小与变色

//用键盘控制DIV,红色方块为键盘操作区域,您可以进行如下操作:左右控制;背景变为绿色;背景变为黄色;背景变为蓝色放大或缩小用键盘控制DIV,红色方块为键盘操作区域,您可以进行如下操作:  上:↑ 下:↓ 左:← 右:→  Ctrl + 1 : 背景变为绿色  Ctrl + 2 : 背景变为黄色  Ctrl + 3 : 背景变为蓝色  Ctrl + ↑ : 放大  Ctrl + ↓ : 缩小 <!-- Author: XiaoWen Create a file: 2017-01-10 19:0

JS实现用键盘控制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> <meta http-equiv="Content-

js键盘控制div移动,解决停顿问题

问题版本代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 <html> <head> <title>键盘控制div移动</title> <meta charset="utf-8" /> <style type="text/css"> #div1{width:100px;height:1

JS实现用键盘控制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> <meta http-equiv="Content-

JS实现用键盘控制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> <meta http-equiv="Content-

键盘控制div上下左右移动 (转)

<html> <head> <title></title> <link rel="stylesheet" type="text/css" href="public/easy_ui/themes/icon.css"> <script type="text/javascript" src="public/easy_ui/jquery.min.js"

js实现键盘操作对div的移动或改变-------Day43

<爸爸去哪儿>的第二季据说要开播了额,有点小期待,不知道这一季的小宝贝们会有多萌,还会甜到心底吧, 哈哈,还记得那个风一样的女子呢,不知道她现在如何了. 言归正传,继续今天的记录,实际上在刚开始的时候,我以为可以很快的实现这个功能,毕竟昨天记录了获取键盘按键的值的事件,有了值,无非就是针对不同值做不同的操作嘛,而且之前曾经在写贪吃蛇时也用到过.结果一捯饬,又是好久的一段时间,所以感觉有必要记录下的,一方面确有可取之处,另一方面也对自己的提醒,刚刚实现过的功能转头又是陌生人了,总的来说,算是温故

CSS3感应鼠标的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>CSS3感应鼠标的div背景闪烁动画效果丨

2016/3/30 ①投票checkbox ②进度条两个div套起百分比控制内div(width) &lt;div&gt;&lt;div&gt;&lt;/div&gt;&lt;/div&gt; ③数据库test2 表 diaoyan... 35岁发展方向投票

分两个页面,要点:提交form 相连action method  两个页面可以合成一个页面action传到自身页面   但分开较清晰 第一个页面vote.php 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="h