代码如下,实现了点击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 > |