1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
2
<html xmlns="http://www.w3.org/1999/xhtml">
3
<head>
4
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
5
<title>无标题文档</title>
6data:image/s3,"s3://crabby-images/77c24/77c24859edfeb98cd4bf5a09471584771ab74bae" alt=""
<script language="javascript">data:image/s3,"s3://crabby-images/02d71/02d712c8d0225d863c9258b891deb6d74b57e2ce" alt=""
7data:image/s3,"s3://crabby-images/f4141/f41410233a438ab5bb0d8605d2f9374e1463a879" alt=""
8
var theP; //P标签对象
9
10data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
var show=function(msg)
{ //直接定义 function show(msg) 效果是一样的
11data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
return function()
{
12
alert(msg+" from show()");
13data:image/s3,"s3://crabby-images/f4141/f41410233a438ab5bb0d8605d2f9374e1463a879" alt=""
14data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
if(window.addEventListener)
{ //FF etc.
15
theP.removeEventListener("click", theP.show11, false);
16
}
17data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
else
{ //IE
18
theP.detachEvent("onclick", theP.show11);
19
}
20
}
21
}
22data:image/s3,"s3://crabby-images/f4141/f41410233a438ab5bb0d8605d2f9374e1463a879" alt=""
23data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
var show2=function(msg)
{ //直接定义 function show2(msg) 效果是一样的
24data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
return function()
{
25
alert(msg+" from show2()");
26
}
27
}
28
29data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
function showDef()
{
30
alert("showDef()");
31
32data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
if(window.addEventListener)
{ //FF etc.
33
theP.removeEventListener("click", showDef, false);
34
}
35data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
else
{ //IE
36
theP.detachEvent("onclick", showDef);
37
}
38
}
39
40data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
window.onload=function()
{
41
theP=document.getElementById("pid");
42
43
theP.show11=show("可以detach的带参数方法");
44
45
if(window.addEventListener) // not IE
46data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
{
47
//for FF.etc
48
theP.addEventListener("click", theP.show11, false);
49
theP.addEventListener("click", showDef, false);
50
}
51
else
52data:image/s3,"s3://crabby-images/f7de4/f7de4b6d587350a91a8d1d3d361655fa1f4e8980" alt=""
{
53
//for IE
54
theP.attachEvent("onclick", theP.show11);
55
theP.attachEvent("onclick", show2('不能detach的带参数方法'));//区别于上一个,这里不能detach
56
57
theP.attachEvent("onclick", showDef); //无参数的方法直接写
58
}
59
}
60
</script>
61data:image/s3,"s3://crabby-images/80126/80126fecf4b3c462abf4ae8400787ee22166c571" alt=""
62
</head>
63data:image/s3,"s3://crabby-images/80126/80126fecf4b3c462abf4ae8400787ee22166c571" alt=""
64
<body >
65
<div >
66
<p id="pid">Click Me</p>
67
</div>
68
</body>
69
</html>
本文系原创,转载请注明:来自 Freeway —— cnBlogs
Tag标签: JavaScript,attachEvent,detachEvent,带参数的函数