手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >点击页面其它地方隐藏该div的两种思路
点击页面其它地方隐藏该div的两种思路
摘要:思路一第一种思路分两步第一步:对document的click事件绑定事件处理程序,使其隐藏该div第二步:对div的click事件绑定事件处...

思路一

第一种思路分两步

第一步:对document的click事件绑定事件处理程序,使其隐藏该div

第二步:对div的click事件绑定事件处理程序,阻止事件冒泡,防止其冒泡到document,而调用document的onclick方法隐藏了该div。

复制代码 代码如下:

<script type="text/javascript">

function stopPropagation(e) {

if (e.stopPropagation)

e.stopPropagation();

else

e.cancelBubble = true;

}

$(document).bind('click',function(){

$('#test').css('display','none');

});

$('#test').bind('click',function(e){

stopPropagation(e);

});

</script>

这样当点击页面非div区域的时候,直接或层层冒泡会调用document的onclick方法,隐藏该div,而点击div或其子元素的时候,事件总会冒泡的div本身,这时候会阻止事件继续冒泡,不会调用doument的onclick方法致使div被隐藏,从而完成了我们的需求。

思路二

我们之前提到,在触发DOM上的某个事件的时候会产生一个事件对象event,这个对象包含着所有与事件有关的信息,包括产生事件的元素、事件类型等相关信息,思路一中div的click事件处理程序传入的参数就是这个event对象。访问IE中的event对象有几种不同的方式,取决于指定事件处理程序的方法。直接为DOM元素添加事件处理程序时,event对象作为window对象的一个属性存在。

event对象包含了一个重要属性:target(W3C)/srcElement(IE),这个属性标识了触发事件的原始元素,思路二就是要利用这个属性。我们可以直接对document的click事件绑定事件处理程序,在事件处理程序中判读事件源是否为id==test的div元素或其子元素,如果是则方法return不做操作,如果不是则隐藏该div。

复制代码 代码如下:

<script type="text/javascript">

$(document).bind('click',function(e){

var e = e || window.event; //浏览器兼容性

var elem = e.target || e.srcElement;

while (elem) { //循环判断至跟节点,防止点击的是div子元素

if (elem.id && elem.id=='test') {

return;

}

elem = elem.parentNode;

}

$('#test').css('display','none'); //点击的不是div或其子元素

});

</script>

这样当点击页面任何地方的时候都会层层冒泡至document的click事件,事件处理程序会判断事件源是否为id==test的div或其子元素,如果是方法return,否则隐藏该div,也能够实现我们的需求。

【点击页面其它地方隐藏该div的两种思路】相关文章:

JavaScript中的Math.E属性使用详解

列表内容的选择

jQuery替换textarea中换行的方法

JavaScript实现斗地主游戏的思路

文本加密解密

用JavaScript实现页面重定向功能的教程

JS获取当前脚本文件的绝对路径

js控制网页前进和后退的方法

Javascript实现的SHA-256加密算法完整实例

javascript中clipboardData对象用法

精品推荐
分类导航