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事件中,加入下列代码:
setCapture和releaseCapture的小应用function change_capture(obj)
}
4).divMain的onclick事件中,加入下列代码:
setCapture和releaseCapture的小应用function click_func()
}
5).对ALT+F4进行处理,在body的onkeydown事件中加入下列代码:
setCapture和releaseCapture的小应用function keydown_func()
}
完整代码如下:
setCapture和releaseCapture的小应用<HTML> 
setCapture和releaseCapture的小应用    
<head>
setCapture和releaseCapture的小应用        
<title>setCapture和releaseCapture的小应用</title>
>
注意:该实例仅能应用于IE
源代码: https://files.cnblogs.com/redleaf1995/capture.rar

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2021-06-05
  • 2021-08-12
  • 2022-12-23
  • 2022-02-14
  • 2022-12-23
  • 2021-07-09
猜你喜欢
  • 2022-02-18
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-03-04
  • 2022-12-23
相关资源
相似解决方案