setCapture和releaseCapture的小应用

web开发和windows开发最大的区别就是windows开发是有状态的,而web开发是无状态的,在windows中,一切操作都可以由程序来控制 ,除非强制执行ctrl+alt+del;但web操作就不一样了,即使执行很重要的操作,用户一点击浏览器关闭按钮,就将前面操作成果化为乌有.尽管可以在onunload事件中加些代码,让用户可以选择是否退出,但不能从根本上解决问题!
        前几天,从网上看到setCapture方法,了解了一下,大体是这样的意思,当在IE文档某个区域中使用了这个方法,并且写了onclick或者onmouse***等有关的鼠标事件方法,那么它就会监视相应的鼠标操作,即使你的鼠标移出了IE,它也一样能捕获到.如果你在某div中的onclick事件中写了一个alert命令,这时,你点击的关闭按钮,它也一样会弹出alert窗口.releaseCapture与setCapture方法相反,释放鼠标监控.
        利用这个特性,我们可以延缓IE的关闭窗口等破坏性操作,将一些重要的操作能够在破坏性操作执行之前得到处理.
        有一点遗憾:setCapture和releaseCapture 不支持键盘事件.只对onmousedown, onmouseup, onmousemove, onclick, ondblclick, onmouseover, onmouseout这样的鼠标事件起作用.
        下面是一个小例子,若我们要对divMain这个div元素里面的内容进行保护:
         1). 对divMain执行setCapture方法:
document.getElementById("divMain").setCapture();
2).加入一按钮btnChange,可以进行setCapture和releaseCapture切换,定义一全局变量;
var isFreeze = true;
3).在btnChange的onclick事件中,加入下列代码:
function change_capture(obj)
...{
        isFreeze = !isFreeze;
    if(isFreeze)
    ...{
        obj.value = "releaseCapture";
        document.getElementById("divMain").setCapture();
    }
    else
    ...{
        obj.value = "setCapture";
        alert('保存!');                        //可以执行重要操作
        document.getElementById("divMain").releaseCapture();
    }
}4).divMain的onclick事件中,加入下列代码:
function click_func()
...{
    if(event.srcElement.id == "divMain")
    ...{
        alert("处理中...");                                                            //常规操作
        document.getElementById("divMain").setCapture();
    }
    else
    ...{
        if(isFreeze && event.srcElement.id != "btnChange")
        ...{
            alert('未执行releaseCapture,不能点击');
            document.getElementById("divMain").setCapture();
        }
    }
}5).对ALT+F4进行处理,在body的onkeydown事件中加入下列代码:
function keydown_func()
...{
    if (event.keyCode==115  && event.altKey)            //ALT+F4
    ...{
        if(isFreeze)
        ...{
                alert('保存!');                                        //可以执行重要操作
               }           
            //window.showModelessDialog("about:blank","","dialogWidth:1px;dialogheight:1px");           
        //return false;
        }
        document.getElementById("divMain").setCapture();
}完整代码如下:
<HTML>
    <head>
        <title>setCapture和releaseCapture的小应用</title>
        <SCRIPT LANGUAGE="JavaScript">...
        <!--     
            var isFreeze = true;
           
            function click_func()
            ...{
                if(event.srcElement.id == "divMain")
                ...{
                    alert("处理中...");                                                            //常规操作
                    document.getElementById("divMain").setCapture();
                }
                else
                ...{
                    if(isFreeze && event.srcElement.id != "btnChange")
                    ...{
                        alert('未执行releaseCapture,不能点击');
                        document.getElementById("divMain").setCapture();
                    }
                }
            }
           
            function keydown_func()
            ...{
               
                if (event.keyCode==115  && event.altKey)            //ALT+F4
                ...{
                    if(isFreeze)
                    ...{
                alert('保存!');                                        //可以执行重要操作
               }
           
            //window.showModelessDialog("about:blank","","dialogWidth:1px;dialogheight:1px");
           
                    //return false;
        }
        document.getElementById("divMain").setCapture();
            }
           
            function change_capture(obj)
            ...{
                isFreeze = !isFreeze;
                if(isFreeze)
                ...{
                    obj.value = "releaseCapture";
                    document.getElementById("divMain").setCapture();
                }
                else
                ...{
                    obj.value = "setCapture";
                    alert('保存!');                                    //可以执行重要操作
                    document.getElementById("divMain").releaseCapture();
                }
            }
        //-->
        </SCRIPT>
    </head>
    <BODY  onkeydown="keydown_func();">
        <div id="divMain" style="width:500px;height:400px;border:1px solid #999;padding:2px" onclick="click_func();">
            点一下IE的菜单或者按钮看看:) 又或者IE窗口外的地方
            <input type="button" value="releaseCapture" onclick="change_capture(this);" id="btnChange">
            <script language="javascript">...
                document.getElementById("divMain").setCapture();
            </script>
        </div>
       
    </BODY>
</HTML>注意:该实例仅能应用于IE


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/redleaf1995/archive/2008/03/06/2154784.aspx

posted on 2010-06-22 17:08 飞熊 阅读(861) 评论(0)  编辑  收藏 所属分类: javaScript


只有注册用户登录后才能发表评论。


网站导航:
 
<2010年6月>
303112345
6789101112
13141516171819
20212223242526
27282930123
45678910

导航

统计

常用链接

留言簿(1)

随笔分类

随笔档案

文章分类

文章档案

收藏夹

搜索

最新评论

阅读排行榜

评论排行榜