setCapture和releaseCapture的小应用「建议收藏」 web开发和windows开发最大的区别就是windows开发是有状态的,而web开发是无状态的,在windows中,一切操作都可以由程序来控制,除非强制执行ctrl+alt+del;但web操作就不一样了,即使执行很重要的操作,用户一点击浏览器关闭按钮,就将前面操作成果化为乌有.尽管可以在onunload事件中加些代码,让用户可以选择是否退出,但不能从根本上解决问题!
大家好,又见面了,我是你们的朋友全栈君。 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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/134979.html 原文链接:https://javaforall.net