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

源代码:点此进入下载页面

博客园下载地址:http://www.cnblogs.com/Files/redleaf1995/capture.rar

setCapture和releaseCapture的小应用相关推荐

  1. setCapture和releaseCapture的小应用(转)

    web开发和windows开发最大的区别就是windows开发是有状态的,而web开发是无状态的,在windows中,一切操作都可以由程序来控制 ,除非强制执行ctrl+alt+del;但web操作就 ...

  2. setCapture和releaseCapture

    setCapture函数的作用就是将后续的mouse事件都发送给这个对象,releaseCapture就是将鼠标事件还回去,由 document.window.object之类的自行来处理.这样就保证 ...

  3. setCapture 和 releaseCapture

    setCapture函数的作用就是将后续的mouse事件都发送给这个对象,releaseCapture就是将鼠标事件还回去,由 document.window.object之类的自行来处理.这样就保证 ...

  4. 理解SetCapture、ReleaseCapture、GetCapture(控制了消息发往哪个窗口,是理解消息的关键)

    理解SetCapture.ReleaseCapture.GetCapture 正常情况下,鼠标指针位于哪个窗口区域内,鼠标消息就自动发给哪个窗口.如果调用了SetCapture,之后无论鼠标的位置在哪 ...

  5. win32中SetCapture 和 ReleaseCapture的使用

    最近在用win32写<visual C++经典游戏程序设计>中的扫雷游戏,在写到鼠标点击雷区的时候用到了SetCapture,和ReleaseCapture这对系统函数. 那么为什么需要用 ...

  6. SetCapture()和ReleaseCapture()

    查MSND,对SetCapture()函数的说明为:"该函数在属于当前线程的指定窗口里设置鼠标捕获.一旦窗口捕获了鼠标,所有鼠标输入都针对该窗口,无论光标是否在窗口的边界内.同一时刻只能有一 ...

  7. 关于SetCapture() 和 ReleaseCapture()的使用方法

    查MSND,对SetCapture()函数的说明为:"该函数在属于当前线程的指定窗体里设置鼠标捕获.一旦窗体捕获了鼠标,全部鼠标输入都针对该窗体,不管光标是否在窗体的边界内.同一时刻仅仅能有 ...

  8. 关于SetCapture() 和 ReleaseCapture()的用法

    http://blog.csdn.net/lanyzh0909/article/details/5543399 查MSND,对SetCapture()函数的说明为:"该函数在属于当前线程的指 ...

  9. 关于SetCapture() 和 ReleaseCapture()的用法的个人理解

    1. 函数功能:在当前线程的指定窗口里设置鼠标捕获.一旦窗口捕获了鼠标,所有鼠标输入都针对该窗口,无论光标是否在窗口的边界内还是边界外.同一时刻只能有一个窗口捕获鼠标. 2. 失效条件: A. 当鼠标 ...

最新文章

  1. GOF23设计模式(创建型模式)工厂模式
  2. spring boot 临时文件过期
  3. C# 利用反射调用类下的方法
  4. 关于WriteFile函数的lpNumberOfBytesWritten在Win8开始的不同
  5. Java反射 - 2(对象复制,父类域,内省)
  6. aspose java_Aspose.Cells for Java
  7. 3.10 SE11创建类型组
  8. 腾讯云三大自研数据库之一 TBase 开源后首次重磅升级,复杂查询性能最高提升十倍
  9. java面试题(杨晓峰)---第七讲谈谈int和integer有什么区别?
  10. 渗透测试常用端口利用总结
  11. 捷联惯导系统模型及仿真
  12. IPv6笔记-地址结构与分类
  13. 死锁产生的原因及解决方法
  14. 农户在集市上卖西瓜,他总共有1020个西瓜,第一天卖掉一半多两个,第二天卖掉剩下的一半多两个, 问照此规律实下去,该农户几天能将所有的西瓜卖完。C语言
  15. windows升级卡在配置更新96%
  16. LSD_SLAM 编译、安装到运行demo
  17. PHP数组关于数字键名的问题
  18. git fetch - git merge - git pull 指令
  19. ffmpeg下载m3u8工具大全
  20. 领芯微基于LCM32F037吹风筒方案

热门文章

  1. Mott-insulator transitions in BEC
  2. 本地计算机上的mysql服务启动后停止,某些服务在未由其他服务或程序使用时将自动停止。
  3. 如何初始化阿里云服务器
  4. WPS表格甘特图制作教程
  5. VR全景技术的优点有哪些?
  6. 苹果xsmax怎么开机_苹果XSMAX手机进水不开机怎么办?看小伙如何完美修复!
  7. OpenCV图像旋转(cv::rotate)与镜像(cv::flip)
  8. ssis 转换中文字符乱码_SSIS软件包中的字符映射转换
  9. 【Beta】Scrum Meeting 4
  10. 西北农林科技大学计算机真题,2021西北农林科技大学考研历年真题