时间:2021-07-01 10:21:17 帮助过:35人阅读
function change_capture(obj) {
isFreeze = !isFreeze;
if(isFreeze) {
obj.value = "releaseCapture";
document.getElementById("divMain").setCapture();
} else {
obj.value = "setCapture";
alert('保存!'); //可以执行重要操作
document.getElementById("divMain").releaseCapture();
}
}
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();
}
}
}
对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>
< !--
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" 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>
关于javascript中call和apply函数的应用
我们经常在javascipt中的面向对象应用中遇到call和apply函数;有时会被搞糊涂。其实它们可以改变函数或对象中的this保留字的值;this保留字的默认值就是这个类本身。举例说明:
代码如下:
<!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=gb2312" />
<script language="javascript">
test = {
value: 'default',exec: function() {
alert(this.value);
}
}
function hhh(obj) {
test.exec();test.exec.apply(obj);
}
</script>
</head>
<body>
<input type="button" onclick="hhh(this);" value="test" />
</body>
</html>
运行以上的页面就很快明白了.
call和apply函数可以处理匿名函数
关于类的初始化应用如下:
代码如下:
Person = function() {
this.Init.apply(this, arguments);
};
Person.prototype = {
first: null,
last: null,
Init: function(first, last) {
this.first = first;
this.last = last;
},
fullName: function() {
return this.first + ' ' + this.last;
},
fullNameReversed: function() {
return this.last + ', ' + this.first;
}
};
var s = new Person2('creese', 'yang');
alert(s.fullName());
alert(s.fullNameReversed());
call和apply函数可以赋值函数内容(带匿名参数;但不触发)
关于函数绑定事件应用如下:
代码如下:
Function.prototype.BindForEvent = function() {
var __m = this, object = arguments[0], args = new Array();
for(var i = 1; i < arguments.length; i++){
args.push(arguments[i]);
}
return function(event) {
return __m.apply(object, [( event || window.event)].concat(args));
}
}
call和apply函数关于函数绑定参数应用如下:
代码如下:
Function.prototype.Bind = function() {
var __m = this, object = arguments[0], args = new Array();
for(var i = 1; i < arguments.length; i++){
args.push(arguments[i]);
}
return function() {
return __m.apply(object, args);
}
}
call和apply函数功能是一样的;就是参数格式不同;fun.call(obj, arguments);apply的arguments是数组形式;call则是单数形式。