代码如下,实现了点击input显示一个div层,当点击除input和div以外的地方的时候,隐藏div的功能。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
|
<!DOCTYPE html>
< html >
< head >
< meta charset = "utf-8" />
< title >点击其它地方关闭DIV</ title >
</ head >
< body >
< input type = "text" value = "" id = "tf" />
< div style = "width:400px; height:200px;border:1px solid #000;display:none" id = "con" >
< p >1111</ p >
< p >< span >2222</ span ></ p >
< p >< a href = "#" >3333</ a ></ p >
</ div >
< script >
function e(obj){return document.getElementById(obj)}
e('tf').onclick=function(event){
e('con').style.display='block';
stopBubble(event);
document.onclick=function(){
e('con').style.display='none';
document.onclick=null;
}
}
e('con').onclick=function(event){
//只阻止了向上冒泡,而没有阻止向下捕获,所以点击con的内部对象时,仍然可以执行这个函数
stopBubble(event);
}
//阻止冒泡函数
function stopBubble(e){
if(e && e.stopPropagation){
e.stopPropagation(); //w3c
}else{
window.event.cancelBubble=true; //IE
}
}
</ script >
</ body >
</ html >
|